home *** CD-ROM | disk | FTP | other *** search
/ EuroCD 3 / EuroCD 3.iso / Programming / BlitzBasic / Gorny3Dset / 3dlib.bb2 next >
Unknown  |  1998-06-24  |  52.9 KB

open in: MacOS 8.1     |     Win98     |     DOS

view JSON data     |     view as text

This file was not able to be converted.
This format is not currently supported by dexvert.

ConfidenceProgramDetectionMatch TypeSupport
100% file data default
100% gt2 Kopftext: '; 2B3D' default (weak)



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 3b 20 32 42 33 44 00 3b | 20 42 6c 69 74 7a 20 42 |; 2B3D.;| Blitz B|
|00000010| 61 73 69 63 20 49 49 20 | 33 44 20 47 72 61 70 68 |asic II |3D Graph|
|00000020| 69 63 73 20 45 6e 67 69 | 6e 65 00 3b 20 56 65 72 |ics Engi|ne.; Ver|
|00000030| 73 69 6f 6e 20 30 2e 39 | 00 3b 00 00 2e 64 65 66 |sion 0.9|.;...def|
|00000040| 69 6e 69 74 69 6f 6e 73 | 00 00 23 4d 41 58 50 4f |initions|..#MAXPO|
|00000050| 49 4e 54 53 20 20 20 20 | 3d 20 20 20 20 34 20 20 |INTS |= 4 |
|00000060| 3b 6d 61 78 20 70 6f 69 | 6e 74 73 20 70 65 72 20 |;max poi|nts per |
|00000070| 70 6f 6c 79 67 6f 6e 00 | 23 4d 41 58 50 4f 4c 59 |polygon.|#MAXPOLY|
|00000080| 47 4f 4e 53 20 20 3d 20 | 20 20 33 32 20 20 3b 6d |GONS = | 32 ;m|
|00000090| 61 78 20 70 6f 6c 79 67 | 6f 6e 73 20 70 65 72 20 |ax polyg|ons per |
|000000a0| 6f 62 6a 65 63 74 00 23 | 4d 41 58 56 45 52 54 53 |object.#|MAXVERTS|
|000000b0| 4f 42 4a 20 20 3d 20 20 | 31 32 38 20 20 3b 6d 61 |OBJ = |128 ;ma|
|000000c0| 78 20 76 65 72 74 69 63 | 65 73 20 70 65 72 20 6f |x vertic|es per o|
|000000d0| 62 6a 65 63 74 00 23 4d | 41 58 4f 42 4a 45 43 54 |bject.#M|AXOBJECT|
|000000e0| 53 20 20 20 3d 20 20 20 | 33 32 20 20 3b 6d 61 78 |S = |32 ;max|
|000000f0| 20 4f 42 4a 45 43 54 53 | 20 70 65 72 20 33 64 20 | OBJECTS| per 3d |
|00000100| 77 6f 72 6c 64 00 23 4d | 41 58 50 4f 4c 59 46 52 |world.#M|AXPOLYFR|
|00000110| 41 4d 45 20 3d 20 31 30 | 32 34 20 20 3b 6d 61 78 |AME = 10|24 ;max|
|00000120| 20 70 6f 6c 79 67 6f 6e | 73 20 69 6e 20 61 20 66 | polygon|s in a f|
|00000130| 72 61 6d 65 20 28 31 36 | 2a 31 32 29 00 00 23 46 |rame (16|*12)..#F|
|00000140| 4c 41 54 20 20 20 20 20 | 20 20 20 20 3d 20 30 20 |LAT | = 0 |
|00000150| 20 20 20 20 3b 73 68 61 | 64 69 6e 67 20 74 79 70 | ;sha|ding typ|
|00000160| 65 00 23 43 4f 4e 53 54 | 41 4e 54 20 20 20 20 20 |e.#CONST|ANT |
|00000170| 3d 20 31 00 00 23 5a 50 | 4c 41 4e 45 20 20 20 20 |= 1..#ZP|LANE |
|00000180| 20 20 20 3d 20 30 20 20 | 20 20 20 3b 63 6c 69 70 | = 0 | ;clip|
|00000190| 70 69 6e 67 20 62 6f 75 | 6e 64 61 72 69 65 73 00 |ping bou|ndaries.|
|000001a0| 23 46 52 55 53 54 55 4d | 20 20 20 20 20 20 3d 20 |#FRUSTUM| = |
|000001b0| 31 00 00 80 01 2e 6d 61 | 74 72 69 78 34 78 34 00 |1.....ma|trix4x4.|
|000001c0| 20 20 72 30 2e 66 5b 34 | 5d 00 20 20 72 31 2e 66 | r0.f[4|]. r1.f|
|000001d0| 5b 34 5d 00 20 20 72 32 | 2e 66 5b 34 5d 00 20 20 |[4]. r2|.f[4]. |
|000001e0| 72 33 2e 66 5b 34 5d 00 | 80 02 20 80 01 00 00 80 |r3.f[4].|.. .....|
|000001f0| 01 2e 6d 61 74 72 69 78 | 31 78 34 00 20 20 72 2e |..matrix|1x4. r.|
|00000200| 66 5b 34 5d 00 80 02 20 | 80 01 00 00 80 01 2e 76 |f[4]... |.......v|
|00000210| 65 63 74 6f 72 00 20 20 | 78 2e 66 3a 79 3a 7a 3a |ector. |x.f:y:z:|
|00000220| 77 00 80 02 20 80 01 00 | 00 80 01 2e 76 65 72 74 |w... ...|....vert|
|00000230| 65 78 00 20 20 78 2e 66 | 3a 79 3a 7a 00 80 02 20 |ex. x.f|:y:z... |
|00000240| 80 01 00 00 80 01 2e 70 | 69 78 65 6c 00 20 20 78 |.......p|ixel. x|
|00000250| 2e 77 3a 79 00 80 02 20 | 80 01 00 00 80 01 2e 6c |.w:y... |.......l|
|00000260| 69 6e 65 00 61 2e 76 65 | 72 74 65 78 3a 62 00 80 |ine.a.ve|rtex:b..|
|00000270| 02 20 80 01 00 00 80 01 | 2e 70 6f 6c 79 74 65 6d |. ......|.polytem|
|00000280| 70 00 78 31 2e 77 3a 79 | 31 3a 78 32 3a 79 32 3a |p.x1.w:y|1:x2:y2:|
|00000290| 78 33 3a 79 33 3a 78 34 | 3a 79 34 00 80 02 20 80 |x3:y3:x4|:y4... .|
|000002a0| 01 00 00 80 01 2e 64 69 | 72 33 64 00 20 20 61 6e |......di|r3d. an|
|000002b0| 67 78 2e 6c 3a 61 6e 67 | 79 3a 61 6e 67 7a 00 80 |gx.l:ang|y:angz..|
|000002c0| 02 20 80 01 00 00 80 01 | 2e 72 67 62 74 79 70 65 |. ......|.rgbtype|
|000002d0| 00 20 20 72 2e 77 3a 67 | 3a 62 00 80 02 20 80 01 |. r.w:g|:b... ..|
|000002e0| 00 00 80 01 2e 70 6f 6c | 79 67 6f 6e 00 20 20 6e |.....pol|ygon. n|
|000002f0| 75 6d 70 6f 69 6e 74 73 | 2e 77 00 20 20 63 6f 6c |umpoints|.w. col|
|00000300| 6f 72 2e 77 00 20 20 73 | 68 61 64 65 2e 77 00 20 |or.w. s|hade.w. |
|00000310| 20 73 68 61 64 69 6e 67 | 2e 77 00 20 20 74 77 6f | shading|.w. two|
|00000320| 73 69 64 65 64 2e 62 00 | 20 20 76 69 73 69 62 6c |sided.b.| visibl|
|00000330| 65 2e 62 00 20 20 63 6c | 69 70 70 65 64 2e 62 00 |e.b. cl|ipped.b.|
|00000340| 20 20 61 63 74 69 76 65 | 2e 62 00 20 20 76 65 72 | active|.b. ver|
|00000350| 74 65 78 6c 69 73 74 2e | 6c 5b 23 4d 41 58 50 4f |texlist.|l[#MAXPO|
|00000360| 49 4e 54 53 5d 00 20 20 | 6e 6f 72 6d 61 6c 6c 65 |INTS]. |normalle|
|00000370| 6e 67 74 68 2e 66 00 80 | 02 20 80 01 00 00 80 01 |ngth.f..|. ......|
|00000380| 2e 66 61 63 65 74 00 20 | 20 73 76 61 6c 75 65 2e |.facet. | svalue.|
|00000390| 6c 00 20 20 6e 75 6d 70 | 6f 69 6e 74 73 2e 77 00 |l. nump|oints.w.|
|000003a0| 20 20 63 6f 6c 6f 72 2e | 77 00 20 20 73 68 61 64 | color.|w. shad|
|000003b0| 65 2e 77 00 20 20 73 68 | 61 64 69 6e 67 2e 77 00 |e.w. sh|ading.w.|
|000003c0| 20 20 74 77 6f 73 69 64 | 65 64 2e 62 00 20 20 76 | twosid|ed.b. v|
|000003d0| 69 73 69 62 6c 65 2e 62 | 00 20 20 63 6c 69 70 70 |isible.b|. clipp|
|000003e0| 65 64 2e 62 00 20 20 61 | 63 74 69 76 65 2e 62 00 |ed.b. a|ctive.b.|
|000003f0| 20 20 76 65 72 74 65 78 | 6c 69 73 74 2e 76 65 72 | vertex|list.ver|
|00000400| 74 65 78 5b 23 4d 41 58 | 50 4f 49 4e 54 53 5d 00 |tex[#MAX|POINTS].|
|00000410| 20 20 6e 6f 72 6d 61 6c | 6c 65 6e 67 74 68 2e 66 | normal|length.f|
|00000420| 00 80 02 20 80 01 00 00 | 80 01 2e 6f 62 6a 65 63 |... ....|...objec|
|00000430| 74 6e 6f 64 65 00 20 20 | 69 64 2e 62 00 20 20 6e |tnode. |id.b. n|
|00000440| 61 6d 65 2e 73 00 20 20 | 6e 75 6d 76 65 72 74 73 |ame.s. |numverts|
|00000450| 2e 77 00 20 20 76 6c 6f | 63 61 6c 2e 76 65 72 74 |.w. vlo|cal.vert|
|00000460| 65 78 5b 23 4d 41 58 56 | 45 52 54 53 4f 42 4a 5d |ex[#MAXV|ERTSOBJ]|
|00000470| 00 20 20 76 67 6c 6f 62 | 61 6c 2e 76 65 72 74 65 |. vglob|al.verte|
|00000480| 78 5b 23 4d 41 58 56 45 | 52 54 53 4f 42 4a 5d 00 |x[#MAXVE|RTSOBJ].|
|00000490| 20 20 76 63 61 6d 65 72 | 61 2e 76 65 72 74 65 78 | vcamer|a.vertex|
|000004a0| 5b 23 4d 41 58 56 45 52 | 54 53 4f 42 4a 5d 00 20 |[#MAXVER|TSOBJ]. |
|000004b0| 20 6e 75 6d 70 6f 6c 79 | 73 2e 77 00 20 20 70 6f | numpoly|s.w. po|
|000004c0| 6c 79 73 2e 70 6f 6c 79 | 67 6f 6e 5b 23 4d 41 58 |lys.poly|gon[#MAX|
|000004d0| 50 4f 4c 59 47 4f 4e 53 | 5d 00 20 20 72 61 64 69 |POLYGONS|]. radi|
|000004e0| 75 73 2e 66 00 20 20 73 | 74 61 74 65 2e 62 00 20 |us.f. s|tate.b. |
|000004f0| 20 77 6f 72 6c 64 70 6f | 73 2e 76 65 72 74 65 78 | worldpo|s.vertex|
|00000500| 00 80 02 20 80 01 00 00 | 2e 64 65 63 6c 61 72 61 |... ....|.declara|
|00000510| 74 69 6f 6e 73 00 00 80 | 33 2e 6c 20 48 41 4c 46 |tions...|3.l HALF|
|00000520| 5f 53 43 52 45 45 4e 5f | 57 49 44 54 48 2c 20 48 |_SCREEN_|WIDTH, H|
|00000530| 41 4c 46 5f 53 43 52 45 | 45 4e 5f 48 45 49 47 48 |ALF_SCRE|EN_HEIGH|
|00000540| 54 2c 20 56 49 45 57 49 | 4e 47 5f 44 49 53 54 41 |T, VIEWI|NG_DISTA|
|00000550| 4e 43 45 00 80 33 2e 77 | 20 47 4c 5f 54 52 49 41 |NCE..3.w| GL_TRIA|
|00000560| 4e 47 4c 45 5f 43 4f 4c | 4f 52 2c 20 4d 49 4e 58 |NGLE_COL|OR, MINX|
|00000570| 2c 20 4d 49 4e 59 2c 20 | 4d 41 58 58 2c 20 4d 41 |, MINY, |MAXX, MA|
|00000580| 58 59 2c 20 4d 41 58 49 | 4e 54 45 4e 53 49 54 59 |XY, MAXI|NTENSITY|
|00000590| 00 80 33 2e 6c 20 4e 45 | 41 52 5f 5a 2c 20 46 41 |..3.l NE|AR_Z, FA|
|000005a0| 52 5f 5a 00 80 33 2e 66 | 20 41 53 50 45 43 54 5f |R_Z..3.f| ASPECT_|
|000005b0| 52 41 54 49 4f 2c 20 41 | 4d 42 49 45 4e 54 5f 4c |RATIO, A|MBIENT_L|
|000005c0| 49 47 48 54 2c 20 49 4e | 56 45 52 53 45 5f 41 53 |IGHT, IN|VERSE_AS|
|000005d0| 50 45 43 54 5f 52 41 54 | 49 4f 00 80 33 2e 62 20 |PECT_RAT|IO..3.b |
|000005e0| 43 4c 49 50 5f 4d 4f 44 | 45 00 80 33 2e 76 65 63 |CLIP_MOD|E..3.vec|
|000005f0| 74 6f 72 20 4c 49 47 48 | 54 5f 53 4f 55 52 43 45 |tor LIGH|T_SOURCE|
|00000600| 2c 20 56 49 45 57 5f 50 | 4f 49 4e 54 00 80 33 2e |, VIEW_P|OINT..3.|
|00000610| 64 69 72 33 64 20 56 49 | 45 57 5f 41 4e 47 4c 45 |dir3d VI|EW_ANGLE|
|00000620| 00 80 33 2e 6d 61 74 72 | 69 78 34 78 34 20 47 4c |..3.matr|ix4x4 GL|
|00000630| 4f 42 41 4c 5f 56 49 45 | 57 00 00 80 04 20 80 b3 |OBAL_VIE|W.... ..|
|00000640| 20 4f 42 4a 45 43 54 53 | 2e 6f 62 6a 65 63 74 6e | OBJECTS|.objectn|
|00000650| 6f 64 65 28 23 4d 41 58 | 4f 42 4a 45 43 54 53 29 |ode(#MAX|OBJECTS)|
|00000660| 00 80 04 20 80 b3 20 57 | 4f 52 4c 44 50 4f 4c 59 |... .. W|ORLDPOLY|
|00000670| 53 2e 66 61 63 65 74 28 | 23 4d 41 58 50 4f 4c 59 |S.facet(|#MAXPOLY|
|00000680| 46 52 41 4d 45 29 00 00 | 80 04 20 53 49 4e 54 41 |FRAME)..|.. SINTA|
|00000690| 42 4c 45 2e 66 28 33 36 | 30 29 00 80 04 20 43 4f |BLE.f(36|0)... CO|
|000006a0| 53 54 41 42 4c 45 2e 66 | 28 33 36 30 29 00 00 54 |STABLE.f|(360)..T|
|000006b0| 4f 54 41 4c 5f 4f 42 4a | 45 43 54 53 2e 77 3d 30 |OTAL_OBJ|ECTS.w=0|
|000006c0| 00 3b 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |.;------|--------|
|000006d0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000006e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000006f0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000700| 00 80 08 20 42 75 69 6c | 64 4c 6f 6f 6b 55 70 54 |... Buil|dLookUpT|
|00000710| 61 62 6c 65 73 7b 7d 00 | 3b 20 42 75 69 6c 64 73 |ables{}.|; Builds|
|00000720| 20 61 6c 6c 20 74 68 65 | 20 6c 6f 6f 6b 20 75 70 | all the| look up|
|00000730| 20 74 61 62 6c 65 73 00 | 3b 00 20 20 80 15 20 53 | tables.|;. .. S|
|00000740| 49 4e 54 41 42 4c 45 28 | 29 2c 20 43 4f 53 54 41 |INTABLE(|), COSTA|
|00000750| 42 4c 45 28 29 00 20 20 | 80 33 2e 6c 20 61 6e 67 |BLE(). |.3.l ang|
|00000760| 6c 65 00 20 20 80 33 2e | 66 20 72 61 64 00 20 20 |le. .3.|f rad. |
|00000770| 80 16 20 61 6e 67 6c 65 | 3d 30 20 80 18 20 33 36 |.. angle|=0 .. 36|
|00000780| 30 00 20 20 20 20 72 61 | 64 20 3d 20 80 ba 2a 61 |0. ra|d = ..*a|
|00000790| 6e 67 6c 65 2f 31 38 30 | 00 20 20 20 20 43 4f 53 |ngle/180|. COS|
|000007a0| 54 41 42 4c 45 28 61 6e | 67 6c 65 29 3d e0 05 28 |TABLE(an|gle)=..(|
|000007b0| 72 61 64 29 00 20 20 20 | 20 53 49 4e 54 41 42 4c |rad). | SINTABL|
|000007c0| 45 28 61 6e 67 6c 65 29 | 3d e0 0a 28 72 61 64 29 |E(angle)|=..(rad)|
|000007d0| 00 20 20 80 17 20 61 6e | 67 6c 65 00 80 02 20 80 |. .. an|gle... .|
|000007e0| 08 00 00 3b 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |...;----|--------|
|000007f0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000800| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000810| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000820| 2d 2d 00 2e 44 69 73 70 | 6c 61 79 33 44 00 80 08 |--..Disp|lay3D...|
|00000830| 20 44 69 73 70 6c 61 79 | 33 44 7b 73 63 72 57 2e | Display|3D{scrW.|
|00000840| 6c 2c 20 73 63 72 48 2e | 6c 2c 20 76 64 69 73 74 |l, scrH.|l, vdist|
|00000850| 2e 6c 7d 00 3b 20 50 72 | 65 70 61 72 65 73 20 64 |.l}.; Pr|epares d|
|00000860| 69 73 70 6c 61 79 20 66 | 6f 72 20 33 64 20 65 6e |isplay f|or 3d en|
|00000870| 76 69 72 6f 6e 6d 65 6e | 74 00 3b 00 20 20 80 15 |vironmen|t.;. ..|
|00000880| 20 48 41 4c 46 5f 53 43 | 52 45 45 4e 5f 57 49 44 | HALF_SC|REEN_WID|
|00000890| 54 48 2c 20 48 41 4c 46 | 5f 53 43 52 45 45 4e 5f |TH, HALF|_SCREEN_|
|000008a0| 48 45 49 47 48 54 2c 20 | 41 4d 42 49 45 4e 54 5f |HEIGHT, |AMBIENT_|
|000008b0| 4c 49 47 48 54 00 20 20 | 80 15 20 41 53 50 45 43 |LIGHT. |.. ASPEC|
|000008c0| 54 5f 52 41 54 49 4f 2c | 20 56 49 45 57 49 4e 47 |T_RATIO,| VIEWING|
|000008d0| 5f 44 49 53 54 41 4e 43 | 45 2c 20 47 4c 5f 54 52 |_DISTANC|E, GL_TR|
|000008e0| 49 41 4e 47 4c 45 5f 43 | 4f 4c 4f 52 00 20 20 80 |IANGLE_C|OLOR. .|
|000008f0| 15 20 4d 49 4e 58 2c 20 | 4d 49 4e 59 2c 20 4d 41 |. MINX, |MINY, MA|
|00000900| 58 58 2c 20 4d 41 58 59 | 2c 20 4c 49 47 48 54 5f |XX, MAXY|, LIGHT_|
|00000910| 53 4f 55 52 43 45 2c 20 | 4d 41 58 49 4e 54 45 4e |SOURCE, |MAXINTEN|
|00000920| 53 49 54 59 00 20 20 80 | 15 20 56 49 45 57 5f 50 |SITY. .|. VIEW_P|
|00000930| 4f 49 4e 54 2c 20 56 49 | 45 57 5f 41 4e 47 4c 45 |OINT, VI|EW_ANGLE|
|00000940| 2c 20 4e 45 41 52 5f 5a | 2c 20 46 41 52 5f 5a 2c |, NEAR_Z|, FAR_Z,|
|00000950| 20 49 4e 56 45 52 53 45 | 5f 41 53 50 45 43 54 5f | INVERSE|_ASPECT_|
|00000960| 52 41 54 49 4f 00 20 20 | 42 75 69 6c 64 4c 6f 6f |RATIO. |BuildLoo|
|00000970| 6b 55 70 54 61 62 6c 65 | 73 7b 7d 00 20 20 48 41 |kUpTable|s{}. HA|
|00000980| 4c 46 5f 53 43 52 45 45 | 4e 5f 57 49 44 54 48 3d |LF_SCREE|N_WIDTH=|
|00000990| 73 63 72 57 2f 32 00 20 | 20 48 41 4c 46 5f 53 43 |scrW/2. | HALF_SC|
|000009a0| 52 45 45 4e 5f 48 45 49 | 47 48 54 3d 73 63 72 48 |REEN_HEI|GHT=scrH|
|000009b0| 2f 32 00 20 20 41 53 50 | 45 43 54 5f 52 41 54 49 |/2. ASP|ECT_RATI|
|000009c0| 4f 3d 31 00 20 20 56 49 | 45 57 49 4e 47 5f 44 49 |O=1. VI|EWING_DI|
|000009d0| 53 54 41 4e 43 45 3d 76 | 64 69 73 74 00 20 20 4d |STANCE=v|dist. M|
|000009e0| 49 4e 58 3d 30 00 20 20 | 4d 49 4e 59 3d 30 00 20 |INX=0. |MINY=0. |
|000009f0| 20 4d 41 58 58 3d 73 63 | 72 57 00 20 20 4d 41 58 | MAXX=sc|rW. MAX|
|00000a00| 59 3d 73 63 72 48 00 20 | 20 47 4c 5f 54 52 49 41 |Y=scrH. | GL_TRIA|
|00000a10| 4e 47 4c 45 5f 43 4f 4c | 4f 52 3d 31 00 20 20 41 |NGLE_COL|OR=1. A|
|00000a20| 4d 42 49 45 4e 54 5f 4c | 49 47 48 54 3d 36 00 20 |MBIENT_L|IGHT=6. |
|00000a30| 20 4c 49 47 48 54 5f 53 | 4f 55 52 43 45 5c 78 3d | LIGHT_S|OURCE\x=|
|00000a40| 2d 30 2e 39 31 33 39 31 | 33 2c 20 30 2e 33 38 39 |-0.91391|3, 0.389|
|00000a50| 37 35 39 2c 20 2d 30 2e | 31 31 33 33 36 39 00 20 |759, -0.|113369. |
|00000a60| 20 3b 4c 49 47 48 54 5f | 53 4f 55 52 43 45 5c 78 | ;LIGHT_|SOURCE\x|
|00000a70| 3d 30 2e 39 31 38 39 32 | 36 2c 20 30 2e 32 34 38 |=0.91892|6, 0.248|
|00000a80| 34 33 36 2c 20 2d 30 2e | 33 30 36 33 35 39 00 20 |436, -0.|306359. |
|00000a90| 20 56 49 45 57 5f 50 4f | 49 4e 54 5c 78 3d 30 2c | VIEW_PO|INT\x=0,|
|00000aa0| 20 30 2c 20 30 2c 20 31 | 30 00 20 20 56 49 45 57 | 0, 0, 1|0. VIEW|
|00000ab0| 5f 41 4e 47 4c 45 5c 61 | 6e 67 78 3d 30 2c 20 30 |_ANGLE\a|ngx=0, 0|
|00000ac0| 2c 20 30 00 20 20 4e 45 | 41 52 5f 5a 3d 56 49 45 |, 0. NE|AR_Z=VIE|
|00000ad0| 57 49 4e 47 5f 44 49 53 | 54 41 4e 43 45 00 20 20 |WING_DIS|TANCE. |
|00000ae0| 46 41 52 5f 5a 3d 34 30 | 39 36 00 20 20 49 4e 56 |FAR_Z=40|96. INV|
|00000af0| 45 52 53 45 5f 41 53 50 | 45 43 54 5f 52 41 54 49 |ERSE_ASP|ECT_RATI|
|00000b00| 4f 3d 31 2d 41 53 50 45 | 43 54 5f 52 41 54 49 4f |O=1-ASPE|CT_RATIO|
|00000b10| 00 20 20 43 4c 49 50 5f | 4d 4f 44 45 3d 23 5a 50 |. CLIP_|MODE=#ZP|
|00000b20| 4c 41 4e 45 00 20 20 4d | 41 58 49 4e 54 45 4e 53 |LANE. M|AXINTENS|
|00000b30| 49 54 59 3d 31 35 00 80 | 02 20 80 08 00 00 3b 2d |ITY=15..|. ....;-|
|00000b40| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000b50| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000b60| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000b70| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 00 2e 41 |--------|-----..A|
|00000b80| 73 70 65 63 74 52 61 74 | 69 6f 00 80 08 20 41 73 |spectRat|io... As|
|00000b90| 70 65 63 74 52 61 74 69 | 6f 7b 72 61 74 69 6f 2e |pectRati|o{ratio.|
|00000ba0| 66 7d 00 3b 20 53 65 74 | 73 20 61 20 6e 65 77 20 |f}.; Set|s a new |
|00000bb0| 61 73 70 65 63 74 20 72 | 61 74 69 6f 6e 20 66 6f |aspect r|ation fo|
|00000bc0| 72 20 64 69 73 70 6c 61 | 79 00 3b 00 20 20 80 15 |r displa|y.;. ..|
|00000bd0| 20 41 53 50 45 43 54 5f | 52 41 54 49 4f 00 20 20 | ASPECT_|RATIO. |
|00000be0| 41 53 50 45 43 54 5f 52 | 41 54 49 4f 20 3d 20 72 |ASPECT_R|ATIO = r|
|00000bf0| 61 74 69 6f 00 80 02 20 | 80 08 00 00 3b 2d 2d 2d |atio... |....;---|
|00000c00| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000c10| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000c20| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000c30| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 00 80 08 20 4d |--------|---... M|
|00000c40| 61 6b 65 56 65 63 74 6f | 72 33 44 7b 2a 61 2e 76 |akeVecto|r3D{*a.v|
|00000c50| 65 72 74 65 78 2c 20 2a | 62 2e 76 65 72 74 65 78 |ertex, *|b.vertex|
|00000c60| 2c 20 2a 72 65 73 75 6c | 74 2e 76 65 63 74 6f 72 |, *resul|t.vector|
|00000c70| 7d 00 3b 20 43 72 65 61 | 74 65 73 20 61 20 76 65 |}.; Crea|tes a ve|
|00000c80| 63 74 6f 72 20 66 72 6f | 6d 20 74 77 6f 20 70 6f |ctor fro|m two po|
|00000c90| 69 6e 74 73 20 69 6e 20 | 33 64 20 73 70 61 63 65 |ints in |3d space|
|00000ca0| 2e 00 3b 00 20 20 2a 72 | 65 73 75 6c 74 5c 78 20 |..;. *r|esult\x |
|00000cb0| 3d 20 2a 62 5c 78 20 2d | 20 2a 61 5c 78 00 20 20 |= *b\x -| *a\x. |
|00000cc0| 2a 72 65 73 75 6c 74 5c | 79 20 3d 20 2a 62 5c 79 |*result\|y = *b\y|
|00000cd0| 20 2d 20 2a 61 5c 79 00 | 20 20 2a 72 65 73 75 6c | - *a\y.| *resul|
|00000ce0| 74 5c 7a 20 3d 20 2a 62 | 5c 7a 20 2d 20 2a 61 5c |t\z = *b|\z - *a\|
|00000cf0| 7a 00 80 02 20 80 08 00 | 00 3b 2d 2d 2d 2d 2d 2d |z... ...|.;------|
|00000d00| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000d10| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000d20| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000d30| 2d 2d 2d 2d 2d 2d 2d 2d | 00 80 09 2e 66 20 56 65 |--------|....f Ve|
|00000d40| 63 74 6f 72 4d 61 67 33 | 44 7b 2a 61 2e 76 65 63 |ctorMag3|D{*a.vec|
|00000d50| 74 6f 72 7d 00 3b 20 52 | 65 74 75 72 6e 73 20 61 |tor}.; R|eturns a|
|00000d60| 20 6d 61 67 6e 69 74 75 | 64 65 20 6f 66 20 61 20 | magnitu|de of a |
|00000d70| 76 65 63 74 6f 72 2e 00 | 3b 00 20 20 80 09 20 80 |vector..|;. .. .|
|00000d80| 07 20 e0 0c 28 28 2a 61 | 5c 78 29 5e 32 2b 28 2a |. ..((*a|\x)^2+(*|
|00000d90| 61 5c 79 29 5e 32 2b 28 | 2a 61 5c 7a 29 5e 32 29 |a\y)^2+(|*a\z)^2)|
|00000da0| 00 80 02 20 80 09 00 00 | 3b 2d 2d 2d 2d 2d 2d 2d |... ....|;-------|
|00000db0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000dc0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000dd0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000de0| 2d 2d 2d 2d 2d 2d 2d 00 | 80 09 2e 66 20 44 6f 74 |-------.|...f Dot|
|00000df0| 50 72 6f 64 75 63 74 7b | 2a 75 2e 76 65 63 74 6f |Product{|*u.vecto|
|00000e00| 72 2c 20 2a 76 2e 76 65 | 63 74 6f 72 7d 00 3b 20 |r, *v.ve|ctor}.; |
|00000e10| 52 65 74 75 72 6e 73 20 | 64 6f 74 20 70 72 6f 64 |Returns |dot prod|
|00000e20| 75 63 74 20 6f 66 20 74 | 77 6f 20 76 65 63 74 6f |uct of t|wo vecto|
|00000e30| 72 73 2e 00 3b 00 20 20 | 80 09 20 80 07 20 28 28 |rs..;. |.. .. ((|
|00000e40| 28 2a 75 5c 78 29 2a 28 | 2a 76 5c 78 29 29 2b 28 |(*u\x)*(|*v\x))+(|
|00000e50| 28 2a 75 5c 79 29 2a 28 | 2a 76 5c 79 29 29 2b 28 |(*u\y)*(|*v\y))+(|
|00000e60| 28 2a 75 5c 7a 29 2a 28 | 2a 76 5c 7a 29 29 29 00 |(*u\z)*(|*v\z))).|
|00000e70| 80 02 20 80 09 00 00 3b | 2d 2d 2d 2d 2d 2d 2d 2d |.. ....;|--------|
|00000e80| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000e90| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000ea0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000eb0| 2d 2d 2d 2d 2d 2d 00 80 | 08 20 43 72 6f 73 73 50 |------..|. CrossP|
|00000ec0| 72 6f 64 75 63 74 7b 2a | 75 2e 76 65 63 74 6f 72 |roduct{*|u.vector|
|00000ed0| 2c 20 2a 76 2e 76 65 63 | 74 6f 72 2c 20 2a 6e 6f |, *v.vec|tor, *no|
|00000ee0| 72 6d 61 6c 2e 76 65 63 | 74 6f 72 7d 00 3b 20 52 |rmal.vec|tor}.; R|
|00000ef0| 65 74 75 72 6e 73 20 74 | 68 65 20 63 72 6f 73 73 |eturns t|he cross|
|00000f00| 20 70 72 6f 64 75 63 74 | 20 6f 66 20 74 77 6f 20 | product| of two |
|00000f10| 76 65 63 74 6f 72 73 2e | 00 3b 00 20 20 2a 6e 6f |vectors.|.;. *no|
|00000f20| 72 6d 61 6c 5c 78 20 3d | 20 20 28 28 2a 75 5c 79 |rmal\x =| ((*u\y|
|00000f30| 29 20 2a 20 28 2a 76 5c | 7a 29 20 2d 20 28 2a 75 |) * (*v\|z) - (*u|
|00000f40| 5c 7a 29 20 2a 20 28 2a | 76 5c 79 29 29 00 20 20 |\z) * (*|v\y)). |
|00000f50| 2a 6e 6f 72 6d 61 6c 5c | 79 20 3d 20 2d 28 28 2a |*normal\|y = -((*|
|00000f60| 75 5c 78 29 20 2a 20 28 | 2a 76 5c 7a 29 20 2d 20 |u\x) * (|*v\z) - |
|00000f70| 28 2a 75 5c 7a 29 20 2a | 20 28 2a 76 5c 78 29 29 |(*u\z) *| (*v\x))|
|00000f80| 00 20 20 2a 6e 6f 72 6d | 61 6c 5c 7a 20 3d 20 20 |. *norm|al\z = |
|00000f90| 28 28 2a 75 5c 78 29 20 | 2a 20 28 2a 76 5c 79 29 |((*u\x) |* (*v\y)|
|00000fa0| 20 2d 20 28 2a 75 5c 79 | 29 20 2a 20 28 2a 76 5c | - (*u\y|) * (*v\|
|00000fb0| 78 29 29 00 80 02 20 80 | 08 00 00 3b 2d 2d 2d 2d |x))... .|...;----|
|00000fc0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000fd0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000fe0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000ff0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 00 80 08 20 4d 61 |--------|--... Ma|
|00001000| 74 49 64 65 6e 74 69 74 | 79 34 78 34 7b 2a 69 6d |tIdentit|y4x4{*im|
|00001010| 61 74 72 69 78 2e 6d 61 | 74 72 69 78 34 78 34 7d |atrix.ma|trix4x4}|
|00001020| 00 3b 20 43 72 65 61 74 | 65 73 20 61 20 34 78 34 |.; Creat|es a 4x4|
|00001030| 20 69 64 65 6e 74 69 74 | 79 20 6d 61 74 72 69 78 | identit|y matrix|
|00001040| 2e 00 3b 00 20 20 80 ca | 20 2a 69 6d 61 74 72 69 |..;. ..| *imatri|
|00001050| 78 00 20 20 5c 72 30 5b | 30 5d 3d 30 3a 5c 72 30 |x. \r0[|0]=0:\r0|
|00001060| 5b 31 5d 3d 30 3a 5c 72 | 30 5b 32 5d 3d 30 3a 5c |[1]=0:\r|0[2]=0:\|
|00001070| 72 30 5b 33 5d 3d 30 00 | 20 20 5c 72 31 5b 30 5d |r0[3]=0.| \r1[0]|
|00001080| 3d 30 3a 5c 72 31 5b 31 | 5d 3d 30 3a 5c 72 31 5b |=0:\r1[1|]=0:\r1[|
|00001090| 32 5d 3d 30 3a 5c 72 31 | 5b 33 5d 3d 30 00 20 20 |2]=0:\r1|[3]=0. |
|000010a0| 5c 72 32 5b 30 5d 3d 30 | 3a 5c 72 32 5b 31 5d 3d |\r2[0]=0|:\r2[1]=|
|000010b0| 30 3a 5c 72 32 5b 32 5d | 3d 30 3a 5c 72 32 5b 33 |0:\r2[2]|=0:\r2[3|
|000010c0| 5d 3d 30 00 20 20 5c 72 | 33 5b 30 5d 3d 30 3a 5c |]=0. \r|3[0]=0:\|
|000010d0| 72 33 5b 31 5d 3d 30 3a | 5c 72 33 5b 32 5d 3d 30 |r3[1]=0:|\r3[2]=0|
|000010e0| 3a 5c 72 33 5b 33 5d 3d | 30 00 00 20 20 3b 73 65 |:\r3[3]=|0.. ;se|
|000010f0| 74 20 6d 61 69 6e 20 64 | 69 61 67 6f 6e 61 6c 20 |t main d|iagonal |
|00001100| 74 6f 20 31 73 00 20 20 | 5c 72 30 5b 30 5d 3d 31 |to 1s. |\r0[0]=1|
|00001110| 3a 5c 72 31 5b 31 5d 3d | 31 3a 5c 72 32 5b 32 5d |:\r1[1]=|1:\r2[2]|
|00001120| 3d 31 3a 5c 72 33 5b 33 | 5d 3d 31 00 80 02 20 80 |=1:\r3[3|]=1... .|
|00001130| 08 00 00 3b 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |...;----|--------|
|00001140| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001150| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001160| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001170| 2d 2d 00 80 08 20 4d 61 | 74 5a 65 72 6f 34 78 34 |--... Ma|tZero4x4|
|00001180| 7b 2a 7a 6d 61 74 72 69 | 78 2e 6d 61 74 72 69 78 |{*zmatri|x.matrix|
|00001190| 34 78 34 7d 00 3b 20 5a | 65 72 6f 73 20 6f 75 74 |4x4}.; Z|eros out|
|000011a0| 20 61 20 34 78 34 20 6d | 61 74 72 69 78 2e 00 3b | a 4x4 m|atrix..;|
|000011b0| 00 20 20 80 ca 20 2a 7a | 6d 61 74 72 69 78 00 20 |. .. *z|matrix. |
|000011c0| 20 5c 72 30 5b 30 5d 3d | 30 3a 5c 72 30 5b 31 5d | \r0[0]=|0:\r0[1]|
|000011d0| 3d 30 3a 5c 72 30 5b 32 | 5d 3d 30 3a 5c 72 30 5b |=0:\r0[2|]=0:\r0[|
|000011e0| 33 5d 3d 30 00 20 20 5c | 72 31 5b 30 5d 3d 30 3a |3]=0. \|r1[0]=0:|
|000011f0| 5c 72 31 5b 31 5d 3d 30 | 3a 5c 72 31 5b 32 5d 3d |\r1[1]=0|:\r1[2]=|
|00001200| 30 3a 5c 72 31 5b 33 5d | 3d 30 00 20 20 5c 72 32 |0:\r1[3]|=0. \r2|
|00001210| 5b 30 5d 3d 30 3a 5c 72 | 32 5b 31 5d 3d 30 3a 5c |[0]=0:\r|2[1]=0:\|
|00001220| 72 32 5b 32 5d 3d 30 3a | 5c 72 32 5b 33 5d 3d 30 |r2[2]=0:|\r2[3]=0|
|00001230| 00 20 20 5c 72 33 5b 30 | 5d 3d 30 3a 5c 72 33 5b |. \r3[0|]=0:\r3[|
|00001240| 31 5d 3d 30 3a 5c 72 33 | 5b 32 5d 3d 30 3a 5c 72 |1]=0:\r3|[2]=0:\r|
|00001250| 33 5b 33 5d 3d 30 00 80 | 02 20 80 08 00 00 3b 2d |3[3]=0..|. ....;-|
|00001260| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001270| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001280| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001290| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 00 80 08 |--------|-----...|
|000012a0| 20 4d 61 74 43 6f 70 79 | 34 78 34 7b 2a 73 2e 6d | MatCopy|4x4{*s.m|
|000012b0| 61 74 72 69 78 34 78 34 | 2c 20 2a 64 2e 6d 61 74 |atrix4x4|, *d.mat|
|000012c0| 72 69 78 34 78 34 7d 00 | 3b 20 43 6f 70 69 65 73 |rix4x4}.|; Copies|
|000012d0| 20 6f 6e 65 20 34 78 34 | 20 6d 61 74 72 69 78 20 | one 4x4| matrix |
|000012e0| 74 6f 20 61 6e 6f 74 68 | 65 72 20 34 78 34 00 3b |to anoth|er 4x4.;|
|000012f0| 00 20 20 80 16 20 69 2e | 62 3d 30 20 80 18 20 33 |. .. i.|b=0 .. 3|
|00001300| 00 20 20 20 20 2a 64 5c | 72 30 5b 69 5d 20 3d 20 |. *d\|r0[i] = |
|00001310| 2a 73 5c 72 30 5b 69 5d | 00 20 20 20 20 2a 64 5c |*s\r0[i]|. *d\|
|00001320| 72 31 5b 69 5d 20 3d 20 | 2a 73 5c 72 31 5b 69 5d |r1[i] = |*s\r1[i]|
|00001330| 00 20 20 20 20 2a 64 5c | 72 32 5b 69 5d 20 3d 20 |. *d\|r2[i] = |
|00001340| 2a 73 5c 72 32 5b 69 5d | 00 20 20 20 20 2a 64 5c |*s\r2[i]|. *d\|
|00001350| 72 33 5b 69 5d 20 3d 20 | 2a 73 5c 72 33 5b 69 5d |r3[i] = |*s\r3[i]|
|00001360| 00 20 20 80 17 20 69 00 | 80 02 20 80 08 00 3b 2d |. .. i.|.. ...;-|
|00001370| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001380| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001390| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000013a0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 00 80 08 |--------|-----...|
|000013b0| 20 4d 61 74 50 72 69 6e | 74 34 78 34 7b 2a 70 6d | MatPrin|t4x4{*pm|
|000013c0| 61 74 72 69 78 2e 6d 61 | 74 72 69 78 34 78 34 7d |atrix.ma|trix4x4}|
|000013d0| 00 3b 20 50 72 69 6e 74 | 73 20 63 6f 6e 74 65 6e |.; Print|s conten|
|000013e0| 74 20 6f 66 20 61 20 34 | 78 34 20 6d 61 74 72 69 |t of a 4|x4 matri|
|000013f0| 78 2e 00 3b 00 20 20 dd | 84 20 22 2d 23 23 30 2e |x..;. .|. "-##0.|
|00001400| 30 23 23 22 00 20 20 80 | 16 20 69 2e 62 3d 30 20 |0##". .|. i.b=0 |
|00001410| 80 18 20 33 3a dd 81 20 | 2a 70 6d 61 74 72 69 78 |.. 3:.. |*pmatrix|
|00001420| 5c 72 30 5b 69 5d 2c 22 | 2c 20 22 3a 80 17 20 69 |\r0[i],"|, ":.. i|
|00001430| 3a dd 82 20 22 22 00 20 | 20 80 16 20 69 2e 62 3d |:.. "". | .. i.b=|
|00001440| 30 20 80 18 20 33 3a dd | 81 20 2a 70 6d 61 74 72 |0 .. 3:.|. *pmatr|
|00001450| 69 78 5c 72 31 5b 69 5d | 2c 22 2c 20 22 3a 80 17 |ix\r1[i]|,", ":..|
|00001460| 20 69 3a dd 82 20 22 22 | 00 20 20 80 16 20 69 2e | i:.. ""|. .. i.|
|00001470| 62 3d 30 20 80 18 20 33 | 3a dd 81 20 2a 70 6d 61 |b=0 .. 3|:.. *pma|
|00001480| 74 72 69 78 5c 72 32 5b | 69 5d 2c 22 2c 20 22 3a |trix\r2[|i],", ":|
|00001490| 80 17 20 69 3a dd 82 20 | 22 22 00 20 20 80 16 20 |.. i:.. |"". .. |
|000014a0| 69 2e 62 3d 30 20 80 18 | 20 33 3a dd 81 20 2a 70 |i.b=0 ..| 3:.. *p|
|000014b0| 6d 61 74 72 69 78 5c 72 | 33 5b 69 5d 2c 22 2c 20 |matrix\r|3[i],", |
|000014c0| 22 3a 80 17 20 69 3a dd | 82 20 22 22 00 80 02 20 |":.. i:.|. ""... |
|000014d0| 80 08 00 00 3b 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |....;---|--------|
|000014e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000014f0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001500| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001510| 2d 2d 2d 00 80 08 20 4d | 61 74 50 72 69 6e 74 31 |---... M|atPrint1|
|00001520| 78 34 7b 2a 6f 6d 61 74 | 72 69 78 2e 6d 61 74 72 |x4{*omat|rix.matr|
|00001530| 69 78 31 78 34 7d 00 3b | 20 50 72 69 6e 74 73 20 |ix1x4}.;| Prints |
|00001540| 6f 75 74 20 61 20 31 78 | 34 20 6d 61 74 72 69 78 |out a 1x|4 matrix|
|00001550| 20 61 6c 73 6f 20 6b 6e | 6f 77 6e 20 61 73 20 72 | also kn|own as r|
|00001560| 6f 77 20 76 65 63 74 6f | 72 00 3b 00 20 20 dd 84 |ow vecto|r.;. ..|
|00001570| 20 22 23 23 23 23 2e 23 | 23 23 23 22 00 20 20 80 | "####.#|###". .|
|00001580| 16 20 69 2e 62 3d 30 20 | 80 18 20 33 00 20 20 dd |. i.b=0 |.. 3. .|
|00001590| 81 20 2a 6f 6d 61 74 72 | 69 78 5c 72 5b 69 5d 00 |. *omatr|ix\r[i].|
|000015a0| 20 20 80 17 20 69 00 80 | 02 20 80 08 00 00 3b 2d | .. i..|. ....;-|
|000015b0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000015c0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000015d0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000015e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 00 80 08 |--------|-----...|
|000015f0| 20 4d 61 74 4d 75 6c 74 | 34 78 34 7b 2a 41 2e 6d | MatMult|4x4{*A.m|
|00001600| 61 74 72 69 78 34 78 34 | 2c 20 2a 42 2e 6d 61 74 |atrix4x4|, *B.mat|
|00001610| 72 69 78 34 78 34 2c 20 | 2a 52 2e 6d 61 74 72 69 |rix4x4, |*R.matri|
|00001620| 78 34 78 34 7d 00 3b 20 | 4d 75 6c 74 69 70 6c 69 |x4x4}.; |Multipli|
|00001630| 65 73 20 74 77 6f 20 34 | 78 34 20 6d 61 74 72 69 |es two 4|x4 matri|
|00001640| 63 65 73 20 74 6f 67 65 | 74 68 65 72 00 3b 00 20 |ces toge|ther.;. |
|00001650| 20 2a 52 5c 72 30 5b 30 | 5d 3d 28 2a 41 5c 72 30 | *R\r0[0|]=(*A\r0|
|00001660| 5b 30 5d 2a 28 2a 42 5c | 72 30 5b 30 5d 29 29 2b |[0]*(*B\|r0[0]))+|
|00001670| 28 2a 41 5c 72 30 5b 31 | 5d 2a 28 2a 42 5c 72 31 |(*A\r0[1|]*(*B\r1|
|00001680| 5b 30 5d 29 29 2b 28 2a | 41 5c 72 30 5b 32 5d 2a |[0]))+(*|A\r0[2]*|
|00001690| 28 2a 42 5c 72 32 5b 30 | 5d 29 29 2b 28 2a 41 5c |(*B\r2[0|]))+(*A\|
|000016a0| 72 30 5b 33 5d 2a 28 2a | 42 5c 72 33 5b 30 5d 29 |r0[3]*(*|B\r3[0])|
|000016b0| 29 00 20 20 2a 52 5c 72 | 30 5b 31 5d 3d 28 2a 41 |). *R\r|0[1]=(*A|
|000016c0| 5c 72 30 5b 30 5d 2a 28 | 2a 42 5c 72 30 5b 31 5d |\r0[0]*(|*B\r0[1]|
|000016d0| 29 29 2b 28 2a 41 5c 72 | 30 5b 31 5d 2a 28 2a 42 |))+(*A\r|0[1]*(*B|
|000016e0| 5c 72 31 5b 31 5d 29 29 | 2b 28 2a 41 5c 72 30 5b |\r1[1]))|+(*A\r0[|
|000016f0| 32 5d 2a 28 2a 42 5c 72 | 32 5b 31 5d 29 29 2b 28 |2]*(*B\r|2[1]))+(|
|00001700| 2a 41 5c 72 30 5b 33 5d | 2a 28 2a 42 5c 72 33 5b |*A\r0[3]|*(*B\r3[|
|00001710| 31 5d 29 29 00 20 20 2a | 52 5c 72 30 5b 32 5d 3d |1])). *|R\r0[2]=|
|00001720| 28 2a 41 5c 72 30 5b 30 | 5d 2a 28 2a 42 5c 72 30 |(*A\r0[0|]*(*B\r0|
|00001730| 5b 32 5d 29 29 2b 28 2a | 41 5c 72 30 5b 31 5d 2a |[2]))+(*|A\r0[1]*|
|00001740| 28 2a 42 5c 72 31 5b 32 | 5d 29 29 2b 28 2a 41 5c |(*B\r1[2|]))+(*A\|
|00001750| 72 30 5b 32 5d 2a 28 2a | 42 5c 72 32 5b 32 5d 29 |r0[2]*(*|B\r2[2])|
|00001760| 29 2b 28 2a 41 5c 72 30 | 5b 33 5d 2a 28 2a 42 5c |)+(*A\r0|[3]*(*B\|
|00001770| 72 33 5b 32 5d 29 29 00 | 20 20 2a 52 5c 72 30 5b |r3[2])).| *R\r0[|
|00001780| 33 5d 3d 28 2a 41 5c 72 | 30 5b 30 5d 2a 28 2a 42 |3]=(*A\r|0[0]*(*B|
|00001790| 5c 72 30 5b 33 5d 29 29 | 2b 28 2a 41 5c 72 30 5b |\r0[3]))|+(*A\r0[|
|000017a0| 31 5d 2a 28 2a 42 5c 72 | 31 5b 33 5d 29 29 2b 28 |1]*(*B\r|1[3]))+(|
|000017b0| 2a 41 5c 72 30 5b 32 5d | 2a 28 2a 42 5c 72 32 5b |*A\r0[2]|*(*B\r2[|
|000017c0| 33 5d 29 29 2b 28 2a 41 | 5c 72 30 5b 33 5d 2a 28 |3]))+(*A|\r0[3]*(|
|000017d0| 2a 42 5c 72 33 5b 33 5d | 29 29 00 00 20 20 2a 52 |*B\r3[3]|)).. *R|
|000017e0| 5c 72 31 5b 30 5d 3d 28 | 2a 41 5c 72 31 5b 30 5d |\r1[0]=(|*A\r1[0]|
|000017f0| 2a 28 2a 42 5c 72 30 5b | 30 5d 29 29 2b 28 2a 41 |*(*B\r0[|0]))+(*A|
|00001800| 5c 72 31 5b 31 5d 2a 28 | 2a 42 5c 72 31 5b 30 5d |\r1[1]*(|*B\r1[0]|
|00001810| 29 29 2b 28 2a 41 5c 72 | 31 5b 32 5d 2a 28 2a 42 |))+(*A\r|1[2]*(*B|
|00001820| 5c 72 32 5b 30 5d 29 29 | 2b 28 2a 41 5c 72 31 5b |\r2[0]))|+(*A\r1[|
|00001830| 33 5d 2a 28 2a 42 5c 72 | 33 5b 30 5d 29 29 00 20 |3]*(*B\r|3[0])). |
|00001840| 20 2a 52 5c 72 31 5b 31 | 5d 3d 28 2a 41 5c 72 31 | *R\r1[1|]=(*A\r1|
|00001850| 5b 30 5d 2a 28 2a 42 5c | 72 30 5b 31 5d 29 29 2b |[0]*(*B\|r0[1]))+|
|00001860| 28 2a 41 5c 72 31 5b 31 | 5d 2a 28 2a 42 5c 72 31 |(*A\r1[1|]*(*B\r1|
|00001870| 5b 31 5d 29 29 2b 28 2a | 41 5c 72 31 5b 32 5d 2a |[1]))+(*|A\r1[2]*|
|00001880| 28 2a 42 5c 72 32 5b 31 | 5d 29 29 2b 28 2a 41 5c |(*B\r2[1|]))+(*A\|
|00001890| 72 31 5b 33 5d 2a 28 2a | 42 5c 72 33 5b 31 5d 29 |r1[3]*(*|B\r3[1])|
|000018a0| 29 00 20 20 2a 52 5c 72 | 31 5b 32 5d 3d 28 2a 41 |). *R\r|1[2]=(*A|
|000018b0| 5c 72 31 5b 30 5d 2a 28 | 2a 42 5c 72 30 5b 32 5d |\r1[0]*(|*B\r0[2]|
|000018c0| 29 29 2b 28 2a 41 5c 72 | 31 5b 31 5d 2a 28 2a 42 |))+(*A\r|1[1]*(*B|
|000018d0| 5c 72 31 5b 32 5d 29 29 | 2b 28 2a 41 5c 72 31 5b |\r1[2]))|+(*A\r1[|
|000018e0| 32 5d 2a 28 2a 42 5c 72 | 32 5b 32 5d 29 29 2b 28 |2]*(*B\r|2[2]))+(|
|000018f0| 2a 41 5c 72 31 5b 33 5d | 2a 28 2a 42 5c 72 33 5b |*A\r1[3]|*(*B\r3[|
|00001900| 32 5d 29 29 00 20 20 2a | 52 5c 72 31 5b 33 5d 3d |2])). *|R\r1[3]=|
|00001910| 28 2a 41 5c 72 31 5b 30 | 5d 2a 28 2a 42 5c 72 30 |(*A\r1[0|]*(*B\r0|
|00001920| 5b 33 5d 29 29 2b 28 2a | 41 5c 72 31 5b 31 5d 2a |[3]))+(*|A\r1[1]*|
|00001930| 28 2a 42 5c 72 31 5b 33 | 5d 29 29 2b 28 2a 41 5c |(*B\r1[3|]))+(*A\|
|00001940| 72 31 5b 32 5d 2a 28 2a | 42 5c 72 32 5b 33 5d 29 |r1[2]*(*|B\r2[3])|
|00001950| 29 2b 28 2a 41 5c 72 31 | 5b 33 5d 2a 28 2a 42 5c |)+(*A\r1|[3]*(*B\|
|00001960| 72 33 5b 33 5d 29 29 00 | 00 20 20 2a 52 5c 72 32 |r3[3])).|. *R\r2|
|00001970| 5b 30 5d 3d 28 2a 41 5c | 72 32 5b 30 5d 2a 28 2a |[0]=(*A\|r2[0]*(*|
|00001980| 42 5c 72 30 5b 30 5d 29 | 29 2b 28 2a 41 5c 72 32 |B\r0[0])|)+(*A\r2|
|00001990| 5b 31 5d 2a 28 2a 42 5c | 72 31 5b 30 5d 29 29 2b |[1]*(*B\|r1[0]))+|
|000019a0| 28 2a 41 5c 72 32 5b 32 | 5d 2a 28 2a 42 5c 72 32 |(*A\r2[2|]*(*B\r2|
|000019b0| 5b 30 5d 29 29 2b 28 2a | 41 5c 72 32 5b 33 5d 2a |[0]))+(*|A\r2[3]*|
|000019c0| 28 2a 42 5c 72 33 5b 30 | 5d 29 29 00 20 20 2a 52 |(*B\r3[0|])). *R|
|000019d0| 5c 72 32 5b 31 5d 3d 28 | 2a 41 5c 72 32 5b 30 5d |\r2[1]=(|*A\r2[0]|
|000019e0| 2a 28 2a 42 5c 72 30 5b | 31 5d 29 29 2b 28 2a 41 |*(*B\r0[|1]))+(*A|
|000019f0| 5c 72 32 5b 31 5d 2a 28 | 2a 42 5c 72 31 5b 31 5d |\r2[1]*(|*B\r1[1]|
|00001a00| 29 29 2b 28 2a 41 5c 72 | 32 5b 32 5d 2a 28 2a 42 |))+(*A\r|2[2]*(*B|
|00001a10| 5c 72 32 5b 31 5d 29 29 | 2b 28 2a 41 5c 72 32 5b |\r2[1]))|+(*A\r2[|
|00001a20| 33 5d 2a 28 2a 42 5c 72 | 33 5b 31 5d 29 29 00 20 |3]*(*B\r|3[1])). |
|00001a30| 20 2a 52 5c 72 32 5b 32 | 5d 3d 28 2a 41 5c 72 32 | *R\r2[2|]=(*A\r2|
|00001a40| 5b 30 5d 2a 28 2a 42 5c | 72 30 5b 32 5d 29 29 2b |[0]*(*B\|r0[2]))+|
|00001a50| 28 2a 41 5c 72 32 5b 31 | 5d 2a 28 2a 42 5c 72 31 |(*A\r2[1|]*(*B\r1|
|00001a60| 5b 32 5d 29 29 2b 28 2a | 41 5c 72 32 5b 32 5d 2a |[2]))+(*|A\r2[2]*|
|00001a70| 28 2a 42 5c 72 32 5b 32 | 5d 29 29 2b 28 2a 41 5c |(*B\r2[2|]))+(*A\|
|00001a80| 72 32 5b 33 5d 2a 28 2a | 42 5c 72 33 5b 32 5d 29 |r2[3]*(*|B\r3[2])|
|00001a90| 29 00 20 20 2a 52 5c 72 | 32 5b 33 5d 3d 28 2a 41 |). *R\r|2[3]=(*A|
|00001aa0| 5c 72 32 5b 30 5d 2a 28 | 2a 42 5c 72 30 5b 33 5d |\r2[0]*(|*B\r0[3]|
|00001ab0| 29 29 2b 28 2a 41 5c 72 | 32 5b 31 5d 2a 28 2a 42 |))+(*A\r|2[1]*(*B|
|00001ac0| 5c 72 31 5b 33 5d 29 29 | 2b 28 2a 41 5c 72 32 5b |\r1[3]))|+(*A\r2[|
|00001ad0| 32 5d 2a 28 2a 42 5c 72 | 32 5b 33 5d 29 29 2b 28 |2]*(*B\r|2[3]))+(|
|00001ae0| 2a 41 5c 72 32 5b 33 5d | 2a 28 2a 42 5c 72 33 5b |*A\r2[3]|*(*B\r3[|
|00001af0| 33 5d 29 29 00 00 20 20 | 2a 52 5c 72 33 5b 30 5d |3])).. |*R\r3[0]|
|00001b00| 3d 28 2a 41 5c 72 33 5b | 30 5d 2a 28 2a 42 5c 72 |=(*A\r3[|0]*(*B\r|
|00001b10| 30 5b 30 5d 29 29 2b 28 | 2a 41 5c 72 33 5b 31 5d |0[0]))+(|*A\r3[1]|
|00001b20| 2a 28 2a 42 5c 72 31 5b | 30 5d 29 29 2b 28 2a 41 |*(*B\r1[|0]))+(*A|
|00001b30| 5c 72 33 5b 32 5d 2a 28 | 2a 42 5c 72 32 5b 30 5d |\r3[2]*(|*B\r2[0]|
|00001b40| 29 29 2b 28 2a 41 5c 72 | 33 5b 33 5d 2a 28 2a 42 |))+(*A\r|3[3]*(*B|
|00001b50| 5c 72 33 5b 30 5d 29 29 | 00 20 20 2a 52 5c 72 33 |\r3[0]))|. *R\r3|
|00001b60| 5b 31 5d 3d 28 2a 41 5c | 72 33 5b 30 5d 2a 28 2a |[1]=(*A\|r3[0]*(*|
|00001b70| 42 5c 72 30 5b 31 5d 29 | 29 2b 28 2a 41 5c 72 33 |B\r0[1])|)+(*A\r3|
|00001b80| 5b 31 5d 2a 28 2a 42 5c | 72 31 5b 31 5d 29 29 2b |[1]*(*B\|r1[1]))+|
|00001b90| 28 2a 41 5c 72 33 5b 32 | 5d 2a 28 2a 42 5c 72 32 |(*A\r3[2|]*(*B\r2|
|00001ba0| 5b 31 5d 29 29 2b 28 2a | 41 5c 72 33 5b 33 5d 2a |[1]))+(*|A\r3[3]*|
|00001bb0| 28 2a 42 5c 72 33 5b 31 | 5d 29 29 00 20 20 2a 52 |(*B\r3[1|])). *R|
|00001bc0| 5c 72 33 5b 32 5d 3d 28 | 2a 41 5c 72 33 5b 30 5d |\r3[2]=(|*A\r3[0]|
|00001bd0| 2a 28 2a 42 5c 72 30 5b | 32 5d 29 29 2b 28 2a 41 |*(*B\r0[|2]))+(*A|
|00001be0| 5c 72 33 5b 31 5d 2a 28 | 2a 42 5c 72 31 5b 32 5d |\r3[1]*(|*B\r1[2]|
|00001bf0| 29 29 2b 28 2a 41 5c 72 | 33 5b 32 5d 2a 28 2a 42 |))+(*A\r|3[2]*(*B|
|00001c00| 5c 72 32 5b 32 5d 29 29 | 2b 28 2a 41 5c 72 33 5b |\r2[2]))|+(*A\r3[|
|00001c10| 33 5d 2a 28 2a 42 5c 72 | 33 5b 32 5d 29 29 00 20 |3]*(*B\r|3[2])). |
|00001c20| 20 2a 52 5c 72 33 5b 33 | 5d 3d 28 2a 41 5c 72 33 | *R\r3[3|]=(*A\r3|
|00001c30| 5b 30 5d 2a 28 2a 42 5c | 72 30 5b 33 5d 29 29 2b |[0]*(*B\|r0[3]))+|
|00001c40| 28 2a 41 5c 72 33 5b 31 | 5d 2a 28 2a 42 5c 72 31 |(*A\r3[1|]*(*B\r1|
|00001c50| 5b 33 5d 29 29 2b 28 2a | 41 5c 72 33 5b 32 5d 2a |[3]))+(*|A\r3[2]*|
|00001c60| 28 2a 42 5c 72 32 5b 33 | 5d 29 29 2b 28 2a 41 5c |(*B\r2[3|]))+(*A\|
|00001c70| 72 33 5b 33 5d 2a 28 2a | 42 5c 72 33 5b 33 5d 29 |r3[3]*(*|B\r3[3])|
|00001c80| 29 00 80 02 20 80 08 00 | 00 3b 2d 2d 2d 2d 2d 2d |)... ...|.;------|
|00001c90| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001ca0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001cb0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001cc0| 2d 2d 2d 2d 2d 2d 2d 2d | 00 80 08 20 4d 61 74 4d |--------|... MatM|
|00001cd0| 75 6c 74 34 78 34 53 7b | 2a 41 2e 6d 61 74 72 69 |ult4x4S{|*A.matri|
|00001ce0| 78 34 78 34 2c 20 2a 42 | 2e 6d 61 74 72 69 78 34 |x4x4, *B|.matrix4|
|00001cf0| 78 34 2c 20 2a 52 2e 6d | 61 74 72 69 78 34 78 34 |x4, *R.m|atrix4x4|
|00001d00| 7d 00 3b 20 4d 75 6c 74 | 69 70 6c 69 65 73 20 74 |}.; Mult|iplies t|
|00001d10| 77 6f 20 34 78 34 20 6d | 61 74 72 69 63 65 73 20 |wo 4x4 m|atrices |
|00001d20| 74 6f 67 65 74 68 65 72 | 00 3b 00 20 20 2a 52 5c |together|.;. *R\|
|00001d30| 72 30 5b 30 5d 3d 28 2a | 41 5c 72 30 5b 30 5d 2a |r0[0]=(*|A\r0[0]*|
|00001d40| 28 2a 42 5c 72 30 5b 30 | 5d 29 29 2b 28 2a 41 5c |(*B\r0[0|]))+(*A\|
|00001d50| 72 30 5b 31 5d 2a 28 2a | 42 5c 72 31 5b 30 5d 29 |r0[1]*(*|B\r1[0])|
|00001d60| 29 2b 28 2a 41 5c 72 30 | 5b 32 5d 2a 28 2a 42 5c |)+(*A\r0|[2]*(*B\|
|00001d70| 72 32 5b 30 5d 29 29 00 | 20 20 2a 52 5c 72 30 5b |r2[0])).| *R\r0[|
|00001d80| 31 5d 3d 28 2a 41 5c 72 | 30 5b 30 5d 2a 28 2a 42 |1]=(*A\r|0[0]*(*B|
|00001d90| 5c 72 30 5b 31 5d 29 29 | 2b 28 2a 41 5c 72 30 5b |\r0[1]))|+(*A\r0[|
|00001da0| 31 5d 2a 28 2a 42 5c 72 | 31 5b 31 5d 29 29 2b 28 |1]*(*B\r|1[1]))+(|
|00001db0| 2a 41 5c 72 30 5b 32 5d | 2a 28 2a 42 5c 72 32 5b |*A\r0[2]|*(*B\r2[|
|00001dc0| 31 5d 29 29 00 20 20 2a | 52 5c 72 30 5b 32 5d 3d |1])). *|R\r0[2]=|
|00001dd0| 28 2a 41 5c 72 30 5b 30 | 5d 2a 28 2a 42 5c 72 30 |(*A\r0[0|]*(*B\r0|
|00001de0| 5b 32 5d 29 29 2b 28 2a | 41 5c 72 30 5b 31 5d 2a |[2]))+(*|A\r0[1]*|
|00001df0| 28 2a 42 5c 72 31 5b 32 | 5d 29 29 2b 28 2a 41 5c |(*B\r1[2|]))+(*A\|
|00001e00| 72 30 5b 32 5d 2a 28 2a | 42 5c 72 32 5b 32 5d 29 |r0[2]*(*|B\r2[2])|
|00001e10| 29 00 20 20 2a 52 5c 72 | 30 5b 33 5d 3d 30 00 00 |). *R\r|0[3]=0..|
|00001e20| 20 20 2a 52 5c 72 31 5b | 30 5d 3d 28 2a 41 5c 72 | *R\r1[|0]=(*A\r|
|00001e30| 31 5b 30 5d 2a 28 2a 42 | 5c 72 30 5b 30 5d 29 29 |1[0]*(*B|\r0[0]))|
|00001e40| 2b 28 2a 41 5c 72 31 5b | 31 5d 2a 28 2a 42 5c 72 |+(*A\r1[|1]*(*B\r|
|00001e50| 31 5b 30 5d 29 29 2b 28 | 2a 41 5c 72 31 5b 32 5d |1[0]))+(|*A\r1[2]|
|00001e60| 2a 28 2a 42 5c 72 32 5b | 30 5d 29 29 00 20 20 2a |*(*B\r2[|0])). *|
|00001e70| 52 5c 72 31 5b 31 5d 3d | 28 2a 41 5c 72 31 5b 30 |R\r1[1]=|(*A\r1[0|
|00001e80| 5d 2a 28 2a 42 5c 72 30 | 5b 31 5d 29 29 2b 28 2a |]*(*B\r0|[1]))+(*|
|00001e90| 41 5c 72 31 5b 31 5d 2a | 28 2a 42 5c 72 31 5b 31 |A\r1[1]*|(*B\r1[1|
|00001ea0| 5d 29 29 2b 28 2a 41 5c | 72 31 5b 32 5d 2a 28 2a |]))+(*A\|r1[2]*(*|
|00001eb0| 42 5c 72 32 5b 31 5d 29 | 29 00 20 20 2a 52 5c 72 |B\r2[1])|). *R\r|
|00001ec0| 31 5b 32 5d 3d 28 2a 41 | 5c 72 31 5b 30 5d 2a 28 |1[2]=(*A|\r1[0]*(|
|00001ed0| 2a 42 5c 72 30 5b 32 5d | 29 29 2b 28 2a 41 5c 72 |*B\r0[2]|))+(*A\r|
|00001ee0| 31 5b 31 5d 2a 28 2a 42 | 5c 72 31 5b 32 5d 29 29 |1[1]*(*B|\r1[2]))|
|00001ef0| 2b 28 2a 41 5c 72 31 5b | 32 5d 2a 28 2a 42 5c 72 |+(*A\r1[|2]*(*B\r|
|00001f00| 32 5b 32 5d 29 29 00 20 | 20 2a 52 5c 72 31 5b 33 |2[2])). | *R\r1[3|
|00001f10| 5d 3d 30 00 00 20 20 2a | 52 5c 72 32 5b 30 5d 3d |]=0.. *|R\r2[0]=|
|00001f20| 28 2a 41 5c 72 32 5b 30 | 5d 2a 28 2a 42 5c 72 30 |(*A\r2[0|]*(*B\r0|
|00001f30| 5b 30 5d 29 29 2b 28 2a | 41 5c 72 32 5b 31 5d 2a |[0]))+(*|A\r2[1]*|
|00001f40| 28 2a 42 5c 72 31 5b 30 | 5d 29 29 2b 28 2a 41 5c |(*B\r1[0|]))+(*A\|
|00001f50| 72 32 5b 32 5d 2a 28 2a | 42 5c 72 32 5b 30 5d 29 |r2[2]*(*|B\r2[0])|
|00001f60| 29 00 20 20 2a 52 5c 72 | 32 5b 31 5d 3d 28 2a 41 |). *R\r|2[1]=(*A|
|00001f70| 5c 72 32 5b 30 5d 2a 28 | 2a 42 5c 72 30 5b 31 5d |\r2[0]*(|*B\r0[1]|
|00001f80| 29 29 2b 28 2a 41 5c 72 | 32 5b 31 5d 2a 28 2a 42 |))+(*A\r|2[1]*(*B|
|00001f90| 5c 72 31 5b 31 5d 29 29 | 2b 28 2a 41 5c 72 32 5b |\r1[1]))|+(*A\r2[|
|00001fa0| 32 5d 2a 28 2a 42 5c 72 | 32 5b 31 5d 29 29 00 20 |2]*(*B\r|2[1])). |
|00001fb0| 20 2a 52 5c 72 32 5b 32 | 5d 3d 28 2a 41 5c 72 32 | *R\r2[2|]=(*A\r2|
|00001fc0| 5b 30 5d 2a 28 2a 42 5c | 72 30 5b 32 5d 29 29 2b |[0]*(*B\|r0[2]))+|
|00001fd0| 28 2a 41 5c 72 32 5b 31 | 5d 2a 28 2a 42 5c 72 31 |(*A\r2[1|]*(*B\r1|
|00001fe0| 5b 32 5d 29 29 2b 28 2a | 41 5c 72 32 5b 32 5d 2a |[2]))+(*|A\r2[2]*|
|00001ff0| 28 2a 42 5c 72 32 5b 32 | 5d 29 29 00 20 20 2a 52 |(*B\r2[2|])). *R|
|00002000| 5c 72 32 5b 33 5d 3d 30 | 00 00 20 20 2a 52 5c 72 |\r2[3]=0|.. *R\r|
|00002010| 33 5b 30 5d 3d 28 2a 41 | 5c 72 33 5b 30 5d 2a 28 |3[0]=(*A|\r3[0]*(|
|00002020| 2a 42 5c 72 30 5b 30 5d | 29 29 2b 28 2a 41 5c 72 |*B\r0[0]|))+(*A\r|
|00002030| 33 5b 31 5d 2a 28 2a 42 | 5c 72 31 5b 30 5d 29 29 |3[1]*(*B|\r1[0]))|
|00002040| 2b 28 2a 41 5c 72 33 5b | 32 5d 2a 28 2a 42 5c 72 |+(*A\r3[|2]*(*B\r|
|00002050| 32 5b 30 5d 29 2b 2a 42 | 5c 72 33 5b 30 5d 29 00 |2[0])+*B|\r3[0]).|
|00002060| 20 20 2a 52 5c 72 33 5b | 31 5d 3d 28 2a 41 5c 72 | *R\r3[|1]=(*A\r|
|00002070| 33 5b 30 5d 2a 28 2a 42 | 5c 72 30 5b 31 5d 29 29 |3[0]*(*B|\r0[1]))|
|00002080| 2b 28 2a 41 5c 72 33 5b | 31 5d 2a 28 2a 42 5c 72 |+(*A\r3[|1]*(*B\r|
|00002090| 31 5b 31 5d 29 29 2b 28 | 2a 41 5c 72 33 5b 32 5d |1[1]))+(|*A\r3[2]|
|000020a0| 2a 28 2a 42 5c 72 32 5b | 31 5d 29 2b 2a 42 5c 72 |*(*B\r2[|1])+*B\r|
|000020b0| 33 5b 31 5d 29 00 20 20 | 2a 52 5c 72 33 5b 32 5d |3[1]). |*R\r3[2]|
|000020c0| 3d 28 2a 41 5c 72 33 5b | 30 5d 2a 28 2a 42 5c 72 |=(*A\r3[|0]*(*B\r|
|000020d0| 30 5b 32 5d 29 29 2b 28 | 2a 41 5c 72 33 5b 31 5d |0[2]))+(|*A\r3[1]|
|000020e0| 2a 28 2a 42 5c 72 31 5b | 32 5d 29 29 2b 28 2a 41 |*(*B\r1[|2]))+(*A|
|000020f0| 5c 72 33 5b 32 5d 2a 28 | 2a 42 5c 72 32 5b 32 5d |\r3[2]*(|*B\r2[2]|
|00002100| 29 2b 2a 42 5c 72 33 5b | 32 5d 29 00 20 20 2a 52 |)+*B\r3[|2]). *R|
|00002110| 5c 72 33 5b 33 5d 3d 31 | 00 80 02 20 80 08 00 00 |\r3[3]=1|... ....|
|00002120| 3b 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |;-------|--------|
|00002130| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002140| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002150| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 00 |--------|-------.|
|00002160| 80 08 20 4d 61 74 4d 75 | 6c 74 31 78 34 7b 2a 41 |.. MatMu|lt1x4{*A|
|00002170| 2e 6d 61 74 72 69 78 31 | 78 34 2c 20 2a 42 2e 6d |.matrix1|x4, *B.m|
|00002180| 61 74 72 69 78 34 78 34 | 2c 20 2a 52 2e 6d 61 74 |atrix4x4|, *R.mat|
|00002190| 72 69 78 31 78 34 7d 00 | 3b 20 4d 75 74 6c 74 69 |rix1x4}.|; Mutlti|
|000021a0| 70 6c 69 65 73 20 6f 6e | 65 20 31 78 34 20 6d 61 |plies on|e 1x4 ma|
|000021b0| 74 72 69 78 20 77 69 74 | 68 20 34 78 34 20 6d 61 |trix wit|h 4x4 ma|
|000021c0| 74 72 69 78 2e 20 52 65 | 73 75 6c 74 20 69 73 20 |trix. Re|sult is |
|000021d0| 34 78 34 2e 00 3b 20 55 | 73 65 73 20 67 6c 6f 62 |4x4..; U|ses glob|
|000021e0| 61 6c 20 76 61 72 69 61 | 62 6c 65 73 3a 20 2e 2e |al varia|bles: ..|
|000021f0| 2e 5f 31 78 34 2a 2e 2e | 2e 5f 6d 61 74 72 69 78 |._1x4*..|._matrix|
|00002200| 2d 3e 2e 2e 2e 5f 72 65 | 73 75 6c 74 00 3b 00 20 |->..._re|sult.;. |
|00002210| 20 2a 52 5c 72 5b 30 5d | 3d 28 2a 42 5c 72 30 5b | *R\r[0]|=(*B\r0[|
|00002220| 30 5d 2a 28 2a 41 5c 72 | 5b 30 5d 29 29 2b 28 2a |0]*(*A\r|[0]))+(*|
|00002230| 42 5c 72 30 5b 31 5d 2a | 28 2a 41 5c 72 5b 31 5d |B\r0[1]*|(*A\r[1]|
|00002240| 29 29 2b 28 2a 42 5c 72 | 30 5b 32 5d 2a 28 2a 41 |))+(*B\r|0[2]*(*A|
|00002250| 5c 72 5b 32 5d 29 29 2b | 28 2a 42 5c 72 30 5b 33 |\r[2]))+|(*B\r0[3|
|00002260| 5d 2a 28 2a 41 5c 72 5b | 33 5d 29 29 00 20 20 2a |]*(*A\r[|3])). *|
|00002270| 52 5c 72 5b 31 5d 3d 28 | 2a 42 5c 72 31 5b 30 5d |R\r[1]=(|*B\r1[0]|
|00002280| 2a 28 2a 41 5c 72 5b 30 | 5d 29 29 2b 28 2a 42 5c |*(*A\r[0|]))+(*B\|
|00002290| 72 31 5b 31 5d 2a 28 2a | 41 5c 72 5b 31 5d 29 29 |r1[1]*(*|A\r[1]))|
|000022a0| 2b 28 2a 42 5c 72 31 5b | 32 5d 2a 28 2a 41 5c 72 |+(*B\r1[|2]*(*A\r|
|000022b0| 5b 32 5d 29 29 2b 28 2a | 42 5c 72 31 5b 33 5d 2a |[2]))+(*|B\r1[3]*|
|000022c0| 28 2a 41 5c 72 5b 33 5d | 29 29 00 20 20 2a 52 5c |(*A\r[3]|)). *R\|
|000022d0| 72 5b 32 5d 3d 28 2a 42 | 5c 72 32 5b 30 5d 2a 28 |r[2]=(*B|\r2[0]*(|
|000022e0| 2a 41 5c 72 5b 30 5d 29 | 29 2b 28 2a 42 5c 72 32 |*A\r[0])|)+(*B\r2|
|000022f0| 5b 31 5d 2a 28 2a 41 5c | 72 5b 31 5d 29 29 2b 28 |[1]*(*A\|r[1]))+(|
|00002300| 2a 42 5c 72 32 5b 32 5d | 2a 28 2a 41 5c 72 5b 32 |*B\r2[2]|*(*A\r[2|
|00002310| 5d 29 29 2b 28 2a 42 5c | 72 32 5b 33 5d 2a 28 2a |]))+(*B\|r2[3]*(*|
|00002320| 41 5c 72 5b 33 5d 29 29 | 00 20 20 2a 52 5c 72 5b |A\r[3]))|. *R\r[|
|00002330| 33 5d 3d 28 2a 42 5c 72 | 33 5b 30 5d 2a 28 2a 41 |3]=(*B\r|3[0]*(*A|
|00002340| 5c 72 5b 30 5d 29 29 2b | 28 2a 42 5c 72 33 5b 31 |\r[0]))+|(*B\r3[1|
|00002350| 5d 2a 28 2a 41 5c 72 5b | 31 5d 29 29 2b 28 2a 42 |]*(*A\r[|1]))+(*B|
|00002360| 5c 72 33 5b 32 5d 2a 28 | 2a 41 5c 72 5b 32 5d 29 |\r3[2]*(|*A\r[2])|
|00002370| 29 2b 28 2a 42 5c 72 33 | 5b 33 5d 2a 28 2a 41 5c |)+(*B\r3|[3]*(*A\|
|00002380| 72 5b 33 5d 29 29 00 80 | 02 20 80 08 00 00 3b 2d |r[3]))..|. ....;-|
|00002390| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000023a0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000023b0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000023c0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 00 80 09 |--------|-----...|
|000023d0| 2e 73 20 50 4c 47 47 65 | 74 4c 69 6e 65 7b 73 74 |.s PLGGe|tLine{st|
|000023e0| 72 6c 69 6e 65 2e 73 7d | 00 3b 20 53 74 72 69 70 |rline.s}|.; Strip|
|000023f0| 73 20 63 6f 6d 6d 65 6e | 74 73 20 66 72 6f 6d 20 |s commen|ts from |
|00002400| 61 20 73 74 72 6c 69 6e | 65 20 73 74 72 69 6e 67 |a strlin|e string|
|00002410| 2e 2e 2e 00 3b 20 52 65 | 74 75 72 6e 73 20 61 20 |....; Re|turns a |
|00002420| 50 4c 47 20 73 74 72 69 | 6e 67 20 6c 69 6e 65 20 |PLG stri|ng line |
|00002430| 77 69 74 68 6f 75 74 20 | 63 6f 6d 6d 65 6e 74 73 |without |comments|
|00002440| 2e 00 3b 00 20 20 80 33 | 2e 73 20 73 74 72 69 6e |..;. .3|.s strin|
|00002450| 67 2c 20 63 68 61 72 00 | 20 20 63 74 72 2e 62 3d |g, char.| ctr.b=|
|00002460| 31 00 20 20 73 74 72 6c | 69 6e 65 3d dc 92 28 73 |1. strl|ine=..(s|
|00002470| 74 72 6c 69 6e 65 2c 33 | 32 29 00 20 20 63 68 61 |trline,3|2). cha|
|00002480| 72 3d dc 83 28 73 74 72 | 6c 69 6e 65 2c 63 74 72 |r=..(str|line,ctr|
|00002490| 2c 31 29 00 20 20 80 0c | 20 28 28 63 68 61 72 3c |,1). ..| ((char<|
|000024a0| 3e 22 23 22 29 20 80 42 | 20 28 63 68 61 72 3c 3e |>"#") .B| (char<>|
|000024b0| 22 3b 22 29 29 20 80 42 | 20 63 74 72 3c 3d dc 8f |";")) .B| ctr<=..|
|000024c0| 28 73 74 72 6c 69 6e 65 | 29 00 20 20 20 63 74 72 |(strline|). ctr|
|000024d0| 2b 31 00 20 20 20 63 68 | 61 72 3d dc 83 28 73 74 |+1. ch|ar=..(st|
|000024e0| 72 6c 69 6e 65 2c 63 74 | 72 2c 31 29 00 20 20 80 |rline,ct|r,1). .|
|000024f0| c1 00 20 20 73 74 72 69 | 6e 67 3d dc 81 28 73 74 |.. stri|ng=..(st|
|00002500| 72 6c 69 6e 65 2c 63 74 | 72 2d 31 29 00 20 20 73 |rline,ct|r-1). s|
|00002510| 74 72 69 6e 67 3d dc 93 | 28 73 74 72 69 6e 67 2c |tring=..|(string,|
|00002520| 33 32 29 00 20 20 80 09 | 20 80 07 20 73 74 72 69 |32). ..| .. stri|
|00002530| 6e 67 00 80 02 20 80 09 | 00 00 3b 2d 2d 2d 2d 2d |ng... ..|..;-----|
|00002540| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002550| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002560| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002570| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 00 80 08 20 43 6f 6d |--------|-... Com|
|00002580| 70 75 74 65 4f 62 6a 65 | 63 74 52 61 64 69 75 73 |puteObje|ctRadius|
|00002590| 7b 7d 00 3b 20 43 6f 6d | 70 75 74 65 73 20 6d 61 |{}.; Com|putes ma|
|000025a0| 78 69 6d 75 6d 20 72 61 | 64 69 75 73 20 6f 66 20 |ximum ra|dius of |
|000025b0| 61 6e 20 6f 62 6a 65 63 | 74 20 66 6f 72 20 63 6f |an objec|t for co|
|000025c0| 6c 69 73 69 6f 6e 20 64 | 65 74 65 63 74 69 6f 6e |lision d|etection|
|000025d0| 2e 00 3b 20 42 65 74 74 | 65 72 20 6d 65 74 68 6f |..; Bett|er metho|
|000025e0| 64 20 63 6f 75 6c 64 20 | 62 65 20 66 69 6e 64 69 |d could |be findi|
|000025f0| 6e 67 20 61 76 65 72 61 | 67 65 20 72 61 64 69 75 |ng avera|ge radiu|
|00002600| 73 2e 00 3b 00 20 20 80 | 15 20 4f 42 4a 45 43 54 |s..;. .|. OBJECT|
|00002610| 53 28 29 00 20 20 80 33 | 2e 66 20 6e 65 77 5f 72 |S(). .3|.f new_r|
|00002620| 61 64 69 75 73 2c 20 78 | 2c 20 79 2c 20 7a 00 20 |adius, x|, y, z. |
|00002630| 20 80 33 2e 6c 20 69 6e | 64 65 78 00 20 20 80 ca | .3.l in|dex. ..|
|00002640| 20 4f 42 4a 45 43 54 53 | 28 29 00 20 20 5c 72 61 | OBJECTS|(). \ra|
|00002650| 64 69 75 73 3d 30 00 20 | 20 80 16 20 69 6e 64 65 |dius=0. | .. inde|
|00002660| 78 3d 30 20 80 18 20 5c | 6e 75 6d 76 65 72 74 73 |x=0 .. \|numverts|
|00002670| 00 20 20 20 20 78 3d 5c | 76 6c 6f 63 61 6c 5b 69 |. x=\|vlocal[i|
|00002680| 6e 64 65 78 5d 5c 78 00 | 20 20 20 20 79 3d 5c 76 |ndex]\x.| y=\v|
|00002690| 6c 6f 63 61 6c 5b 69 6e | 64 65 78 5d 5c 79 00 20 |local[in|dex]\y. |
|000026a0| 20 20 20 7a 3d 5c 76 6c | 6f 63 61 6c 5b 69 6e 64 | z=\vl|ocal[ind|
|000026b0| 65 78 5d 5c 7a 00 20 20 | 20 20 6e 65 77 5f 72 61 |ex]\z. | new_ra|
|000026c0| 64 69 75 73 3d e0 0c 28 | 78 2a 78 20 2b 20 79 2a |dius=..(|x*x + y*|
|000026d0| 79 20 2b 20 7a 2a 7a 29 | 00 20 20 20 20 80 0b 20 |y + z*z)|. .. |
|000026e0| 28 6e 65 77 5f 72 61 64 | 69 75 73 20 3e 20 5c 72 |(new_rad|ius > \r|
|000026f0| 61 64 69 75 73 29 20 80 | 21 20 5c 72 61 64 69 75 |adius) .|! \radiu|
|00002700| 73 3d 6e 65 77 5f 72 61 | 64 69 75 73 00 20 20 80 |s=new_ra|dius. .|
|00002710| 17 20 69 6e 64 65 78 00 | 80 02 20 80 08 00 00 3b |. index.|.. ....;|
|00002720| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002730| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002740| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00002750| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 00 2e |--------|------..|
|00002760| 50 4c 47 4c 6f 61 64 4f | 62 6a 65 63 74 00 80 08 |PLGLoadO|bject...|
|00002770| 20 50 4c 47 4c 6f 61 64 | 4f 62 6a 65 63 74 7b 66 | PLGLoad|Object{f|
|00002780| 69 6c 65 6e 61 6d 65 2e | 73 2c 20 73 63 61 6c 61 |ilename.|s, scala|
|00002790| 72 2e 66 7d 00 3b 20 52 | 65 61 64 73 20 69 6e 20 |r.f}.; R|eads in |
|000027a0| 61 6e 20 6f 62 6a 65 63 | 74 20 64 61 74 61 20 66 |an objec|t data f|
|000027b0| 72 6f 6d 20 61 20 50 4c | 47 20 66 69 6c 65 2e 00 |rom a PL|G file..|
|000027c0| 3b 20 55 73 65 73 20 67 | 6c 6f 62 61 6c 20 76 61 |; Uses g|lobal va|
|000027d0| 72 69 61 62 6c 65 20 74 | 6f 20 73 74 6f 72 65 20 |riable t|o store |
|000027e0| 72 65 61 64 20 6f 62 6a | 65 63 74 2e 00 3b 00 20 |read obj|ect..;. |
|000027f0| 20 80 15 20 54 4f 54 41 | 4c 5f 4f 42 4a 45 43 54 | .. TOTA|L_OBJECT|
|00002800| 53 2c 20 4f 42 4a 45 43 | 54 53 28 29 00 20 20 80 |S, OBJEC|TS(). .|
|00002810| 33 2e 77 20 74 6f 74 61 | 6c 5f 76 65 72 74 69 63 |3.w tota|l_vertic|
|00002820| 65 73 2c 20 74 6f 74 61 | 6c 5f 70 6f 6c 79 73 2c |es, tota|l_polys,|
|00002830| 20 6e 75 6d 5f 76 65 72 | 74 69 63 65 73 2c 20 63 | num_ver|tices, c|
|00002840| 6f 6c 6f 72 5f 64 65 73 | 00 20 20 80 33 2e 77 20 |olor_des|. .3.w |
|00002850| 6c 6f 67 69 63 61 6c 5f | 63 6f 6c 6f 72 2c 20 73 |logical_|color, s|
|00002860| 68 61 64 69 6e 67 2c 20 | 69 6e 64 65 78 00 20 20 |hading, |index. |
|00002870| 80 33 2e 77 20 6c 6e 2c | 20 74 65 6d 70 77 6f 72 |.3.w ln,| tempwor|
|00002880| 64 2c 20 76 65 72 74 65 | 78 5f 30 2c 20 76 65 72 |d, verte|x_0, ver|
|00002890| 74 65 78 5f 31 2c 20 76 | 65 72 74 65 78 5f 32 00 |tex_1, v|ertex_2.|
|000028a0| 20 20 80 33 2e 62 20 74 | 65 6d 70 62 79 74 65 00 | .3.b t|empbyte.|
|000028b0| 20 20 80 33 2e 66 20 78 | 2c 20 79 2c 20 7a 00 20 | .3.f x|, y, z. |
|000028c0| 20 80 33 2e 76 65 63 74 | 6f 72 20 75 2c 20 76 2c | .3.vect|or u, v,|
|000028d0| 20 6e 6f 72 6d 61 6c 00 | 20 20 80 33 2e 73 20 73 | normal.| .3.s s|
|000028e0| 62 75 66 66 65 72 2c 20 | 6f 62 6a 65 63 74 5f 6e |buffer, |object_n|
|000028f0| 61 6d 65 2c 20 74 65 6d | 70 73 74 72 00 20 20 6c |ame, tem|pstr. l|
|00002900| 6e 3d 30 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |n=0 | |
|00002910| 3b 68 6f 77 20 6d 61 6e | 79 20 61 63 74 75 61 6c |;how man|y actual|
|00002920| 20 50 4c 47 20 63 6f 64 | 65 20 6c 69 6e 65 73 00 | PLG cod|e lines.|
|00002930| 00 80 0b 20 c0 02 28 4f | 42 4a 45 43 54 53 28 29 |... ..(O|BJECTS()|
|00002940| 29 00 20 20 80 ca 20 4f | 42 4a 45 43 54 53 28 29 |). .. O|BJECTS()|
|00002950| 00 20 20 80 0b 20 be 11 | 28 30 2c 66 69 6c 65 6e |. .. ..|(0,filen|
|00002960| 61 6d 65 29 20 20 20 20 | 20 20 20 20 20 20 20 20 |ame) | |
|00002970| 20 20 20 3b 6f 70 65 6e | 20 66 69 6c 65 00 20 20 | ;open| file. |
|00002980| 20 20 be 08 20 30 00 20 | 20 20 20 80 0c 20 80 89 | .. 0. | .. ..|
|00002990| 28 be 0d 28 30 29 29 00 | 20 20 20 20 20 20 73 62 |(..(0)).| sb|
|000029a0| 75 66 66 65 72 3d 50 4c | 47 47 65 74 4c 69 6e 65 |uffer=PL|GGetLine|
|000029b0| 7b dd 01 28 38 30 29 7d | 00 20 20 20 20 20 20 80 |{..(80)}|. .|
|000029c0| 0b 20 73 62 75 66 66 65 | 72 3c 3e 22 22 20 20 20 |. sbuffe|r<>"" |
|000029d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 3b 6e | | ;n|
|000029e0| 6f 74 20 61 6e 20 65 6d | 70 74 79 20 6c 69 6e 65 |ot an em|pty line|
|000029f0| 3f 00 20 20 20 20 20 20 | 20 20 6c 6e 2b 31 20 20 |?. | ln+1 |
|00002a00| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002a10| 20 20 20 20 20 20 20 3b | 69 74 20 69 73 20 61 63 | ;|it is ac|
|00002a20| 74 75 61 6c 20 50 4c 47 | 20 6c 69 6e 65 00 20 20 |tual PLG| line. |
|00002a30| 20 20 20 20 20 20 80 0b | 20 6c 6e 3d 31 20 20 20 | ..| ln=1 |
|00002a40| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002a50| 20 20 20 3b 6d 75 73 74 | 20 62 65 20 61 20 68 65 | ;must| be a he|
|00002a60| 61 64 65 72 20 74 68 65 | 6e 00 20 20 20 20 20 20 |ader the|n. |
|00002a70| 20 20 20 20 74 65 6d 70 | 62 79 74 65 3d dc 89 28 | temp|byte=..(|
|00002a80| 73 62 75 66 66 65 72 2c | 22 20 22 29 00 20 20 20 |sbuffer,|" "). |
|00002a90| 20 20 20 20 20 20 20 5c | 6e 61 6d 65 3d dc 81 28 | \|name=..(|
|00002aa0| 73 62 75 66 66 65 72 2c | 74 65 6d 70 62 79 74 65 |sbuffer,|tempbyte|
|00002ab0| 2d 31 29 00 20 20 20 20 | 20 20 20 20 20 20 74 65 |-1). | te|
|00002ac0| 6d 70 73 74 72 3d dc 82 | 28 73 62 75 66 66 65 72 |mpstr=..|(sbuffer|
|00002ad0| 2c dc 8f 28 73 62 75 66 | 66 65 72 29 2d 74 65 6d |,..(sbuf|fer)-tem|
|00002ae0| 70 62 79 74 65 29 00 20 | 20 20 20 20 20 20 20 20 |pbyte). | |
|00002af0| 20 74 65 6d 70 62 79 74 | 65 3d dc 89 28 74 65 6d | tempbyt|e=..(tem|
|00002b00| 70 73 74 72 2c 22 20 22 | 29 00 20 20 20 20 20 20 |pstr," "|). |
|00002b10| 20 20 20 20 74 6f 74 61 | 6c 5f 76 65 72 74 69 63 | tota|l_vertic|
|00002b20| 65 73 3d bc 01 28 dc 81 | 28 74 65 6d 70 73 74 72 |es=..(..|(tempstr|
|00002b30| 2c 74 65 6d 70 62 79 74 | 65 2d 31 29 29 00 20 20 |,tempbyt|e-1)). |
|00002b40| 20 20 20 20 20 20 20 20 | 74 6f 74 61 6c 5f 70 6f | |total_po|
|00002b50| 6c 79 73 3d bc 01 28 dc | 82 28 74 65 6d 70 73 74 |lys=..(.|.(tempst|
|00002b60| 72 2c dc 8f 28 74 65 6d | 70 73 74 72 29 2d 74 65 |r,..(tem|pstr)-te|
|00002b70| 6d 70 62 79 74 65 29 29 | 00 20 20 20 20 20 20 20 |mpbyte))|. |
|00002b80| 20 20 20 5c 6e 75 6d 76 | 65 72 74 73 3d 74 6f 74 | \numv|erts=tot|
|00002b90| 61 6c 5f 76 65 72 74 69 | 63 65 73 00 20 20 20 20 |al_verti|ces. |
|00002ba0| 20 20 20 20 20 20 5c 6e | 75 6d 70 6f 6c 79 73 3d | \n|umpolys=|
|00002bb0| 74 6f 74 61 6c 5f 70 6f | 6c 79 73 00 20 20 20 20 |total_po|lys. |
|00002bc0| 20 20 20 20 20 20 5c 73 | 74 61 74 65 3d 31 00 20 | \s|tate=1. |
|00002bd0| 20 20 20 20 20 20 20 20 | 20 5c 77 6f 72 6c 64 70 | | \worldp|
|00002be0| 6f 73 5c 78 3d 30 00 20 | 20 20 20 20 20 20 20 20 |os\x=0. | |
|00002bf0| 20 5c 77 6f 72 6c 64 70 | 6f 73 5c 79 3d 30 00 20 | \worldp|os\y=0. |
|00002c00| 20 20 20 20 20 20 20 20 | 20 5c 77 6f 72 6c 64 70 | | \worldp|
|00002c10| 6f 73 5c 7a 3d 30 00 20 | 20 20 20 20 20 20 20 20 |os\z=0. | |
|00002c20| 20 54 4f 54 41 4c 5f 4f | 42 4a 45 43 54 53 2b 31 | TOTAL_O|BJECTS+1|
|00002c30| 00 20 20 20 20 20 20 20 | 20 20 20 5c 69 64 3d 54 |. | \id=T|
|00002c40| 4f 54 41 4c 5f 4f 42 4a | 45 43 54 53 00 20 20 20 |OTAL_OBJ|ECTS. |
|00002c50| 20 20 20 20 20 80 22 00 | 20 20 20 20 20 20 20 20 | .".| |
|00002c60| 20 20 3b 6c 69 73 74 20 | 6f 66 20 76 65 72 74 69 | ;list |of verti|
|00002c70| 63 65 73 20 66 6f 6c 6c | 6f 77 20 6e 6f 77 00 20 |ces foll|ow now. |
|00002c80| 20 20 20 20 20 20 20 20 | 20 3b 6c 6e 3d 32 20 74 | | ;ln=2 t|
|00002c90| 68 72 6f 75 67 68 20 6c | 6e 2b 74 6f 74 61 6c 5f |hrough l|n+total_|
|00002ca0| 76 65 72 74 69 63 65 73 | 00 20 20 20 20 20 20 20 |vertices|. |
|00002cb0| 20 20 20 80 0b 20 28 6c | 6e 3e 3d 32 29 20 80 42 | .. (l|n>=2) .B|
|00002cc0| 20 28 6c 6e 3c 3d 74 6f | 74 61 6c 5f 76 65 72 74 | (ln<=to|tal_vert|
|00002cd0| 69 63 65 73 2b 31 29 00 | 20 20 20 20 20 20 20 20 |ices+1).| |
|00002ce0| 20 20 3b 76 65 72 74 65 | 78 20 6c 69 6e 65 20 64 | ;verte|x line d|
|00002cf0| 69 73 73 65 63 74 65 64 | 20 68 65 72 65 00 00 20 |issected| here.. |
|00002d00| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 73 62 75 | | sbu|
|00002d10| 66 66 65 72 3d dc 92 28 | 73 62 75 66 66 65 72 2c |ffer=..(|sbuffer,|
|00002d20| 33 32 29 00 20 20 20 20 | 20 20 20 20 20 20 20 20 |32). | |
|00002d30| 20 20 74 65 6d 70 62 79 | 74 65 3d dc 89 28 73 62 | tempby|te=..(sb|
|00002d40| 75 66 66 65 72 2c 22 20 | 22 29 00 20 20 20 20 20 |uffer," |"). |
|00002d50| 20 20 20 20 20 20 20 20 | 20 78 3d bc 01 28 dc 81 | | x=..(..|
|00002d60| 28 73 62 75 66 66 65 72 | 2c 74 65 6d 70 62 79 74 |(sbuffer|,tempbyt|
|00002d70| 65 2d 31 29 29 00 20 20 | 20 20 20 20 20 20 20 20 |e-1)). | |
|00002d80| 20 20 20 20 73 62 75 66 | 66 65 72 3d dc 91 28 73 | sbuf|fer=..(s|
|00002d90| 62 75 66 66 65 72 2c 74 | 65 6d 70 62 79 74 65 29 |buffer,t|empbyte)|
|00002da0| 00 00 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.. | |
|00002db0| 73 62 75 66 66 65 72 3d | dc 92 28 73 62 75 66 66 |sbuffer=|..(sbuff|
|00002dc0| 65 72 2c 33 32 29 00 20 | 20 20 20 20 20 20 20 20 |er,32). | |
|00002dd0| 20 20 20 20 20 74 65 6d | 70 62 79 74 65 3d dc 89 | tem|pbyte=..|
|00002de0| 28 73 62 75 66 66 65 72 | 2c 22 20 22 29 00 20 20 |(sbuffer|," "). |
|00002df0| 20 20 20 20 20 20 20 20 | 20 20 20 20 79 3d bc 01 | | y=..|
|00002e00| 28 dc 81 28 73 62 75 66 | 66 65 72 2c 74 65 6d 70 |(..(sbuf|fer,temp|
|00002e10| 62 79 74 65 2d 31 29 29 | 00 20 20 20 20 20 20 20 |byte-1))|. |
|00002e20| 20 20 20 20 20 20 20 73 | 62 75 66 66 65 72 3d dc | s|buffer=.|
|00002e30| 91 28 73 62 75 66 66 65 | 72 2c 74 65 6d 70 62 79 |.(sbuffe|r,tempby|
|00002e40| 74 65 29 00 00 20 20 20 | 20 20 20 20 20 20 20 20 |te).. | |
|00002e50| 20 20 20 73 62 75 66 66 | 65 72 3d dc 92 28 73 62 | sbuff|er=..(sb|
|00002e60| 75 66 66 65 72 2c 33 32 | 29 00 20 20 20 20 20 20 |uffer,32|). |
|00002e70| 20 20 20 20 20 20 20 20 | 74 65 6d 70 62 79 74 65 | |tempbyte|
|00002e80| 3d dc 89 28 73 62 75 66 | 66 65 72 2c 22 20 22 29 |=..(sbuf|fer," ")|
|00002e90| 00 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 80 |. | .|
|00002ea0| 0b 20 74 65 6d 70 62 79 | 74 65 3d 30 20 80 21 20 |. tempby|te=0 .! |
|00002eb0| 74 65 6d 70 62 79 74 65 | 3d dc 8f 28 73 62 75 66 |tempbyte|=..(sbuf|
|00002ec0| 66 65 72 29 00 20 20 20 | 20 20 20 20 20 20 20 20 |fer). | |
|00002ed0| 20 20 20 7a 3d bc 01 28 | dc 81 28 73 62 75 66 66 | z=..(|..(sbuff|
|00002ee0| 65 72 2c 74 65 6d 70 62 | 79 74 65 29 29 00 00 20 |er,tempb|yte)).. |
|00002ef0| 20 20 20 20 20 20 20 20 | 20 20 20 5c 76 6c 6f 63 | | \vloc|
|00002f00| 61 6c 5b 6c 6e 2d 32 5d | 5c 78 3d 78 20 2a 20 73 |al[ln-2]|\x=x * s|
|00002f10| 63 61 6c 61 72 00 20 20 | 20 20 20 20 20 20 20 20 |calar. | |
|00002f20| 20 20 5c 76 6c 6f 63 61 | 6c 5b 6c 6e 2d 32 5d 5c | \vloca|l[ln-2]\|
|00002f30| 79 3d 79 20 2a 20 73 63 | 61 6c 61 72 00 20 20 20 |y=y * sc|alar. |
|00002f40| 20 20 20 20 20 20 20 20 | 20 5c 76 6c 6f 63 61 6c | | \vlocal|
|00002f50| 5b 6c 6e 2d 32 5d 5c 7a | 3d 7a 20 2a 20 73 63 61 |[ln-2]\z|=z * sca|
|00002f60| 6c 61 72 00 20 20 20 20 | 20 20 20 20 20 20 80 22 |lar. | ."|
|00002f70| 00 20 20 20 20 20 20 20 | 20 20 20 20 20 80 0b 20 |. | .. |
|00002f80| 6c 6e 3e 3d 74 6f 74 61 | 6c 5f 76 65 72 74 69 63 |ln>=tota|l_vertic|
|00002f90| 65 73 2b 32 20 80 42 20 | 6c 6e 3c 3d 28 74 6f 74 |es+2 .B |ln<=(tot|
|00002fa0| 61 6c 5f 70 6f 6c 79 73 | 2b 74 6f 74 61 6c 5f 76 |al_polys|+total_v|
|00002fb0| 65 72 74 69 63 65 73 2b | 31 29 00 20 20 20 20 20 |ertices+|1). |
|00002fc0| 20 20 20 20 20 20 20 3b | 70 6f 6c 79 67 6f 6e 20 | ;|polygon |
|00002fd0| 6c 69 6e 65 73 20 64 69 | 73 73 65 63 74 65 64 20 |lines di|ssected |
|00002fe0| 68 65 72 65 00 20 20 20 | 20 20 20 20 20 20 20 20 |here. | |
|00002ff0| 20 74 65 6d 70 62 79 74 | 65 3d dc 89 28 73 62 75 | tempbyt|e=..(sbu|
|00003000| 66 66 65 72 2c 22 20 22 | 29 00 20 20 20 20 20 20 |ffer," "|). |
|00003010| 20 20 20 20 20 20 3b 72 | 65 63 6f 67 6e 69 7a 65 | ;r|ecognize|
|00003020| 20 69 66 20 63 6f 6c 6f | 72 20 69 73 20 69 6e 20 | if colo|r is in |
|00003030| 64 65 63 69 6d 61 6c 20 | 6f 72 20 68 65 78 20 66 |decimal |or hex f|
|00003040| 6f 72 6d 00 20 20 20 20 | 20 20 20 20 20 20 20 20 |orm. | |
|00003050| 80 0b 20 dc 81 28 73 62 | 75 66 66 65 72 2c 32 29 |.. ..(sb|uffer,2)|
|00003060| 3d 22 30 78 22 20 80 8a | 20 dc 81 28 73 62 75 66 |="0x" ..| ..(sbuf|
|00003070| 66 65 72 2c 32 29 3d 22 | 30 58 22 20 80 8a 20 dc |fer,2)="|0X" .. .|
|00003080| 81 28 73 62 75 66 66 65 | 72 2c 31 29 3d 22 24 22 |.(sbuffe|r,1)="$"|
|00003090| 00 20 20 20 20 20 20 20 | 20 20 20 20 20 3b 68 65 |. | ;he|
|000030a0| 78 20 68 61 6e 64 6c 69 | 6e 67 20 6e 6f 74 20 69 |x handli|ng not i|
|000030b0| 6d 70 6c 65 6d 65 74 65 | 64 00 00 20 20 20 20 20 |mplemete|d.. |
|000030c0| 20 20 20 20 20 20 20 80 | 22 00 20 20 20 20 20 20 | .|". |
|000030d0| 20 20 20 20 20 20 3b 64 | 65 63 00 20 20 20 20 20 | ;d|ec. |
|000030e0| 20 20 20 20 20 20 20 20 | 20 63 6f 6c 6f 72 5f 64 | | color_d|
|000030f0| 65 73 3d bc 01 28 dc 81 | 28 73 62 75 66 66 65 72 |es=..(..|(sbuffer|
|00003100| 2c 74 65 6d 70 62 79 74 | 65 2d 31 29 29 00 20 20 |,tempbyt|e-1)). |
|00003110| 20 20 20 20 20 20 20 20 | 20 20 20 20 73 62 75 66 | | sbuf|
|00003120| 66 65 72 3d dc 91 28 73 | 62 75 66 66 65 72 2c 74 |fer=..(s|buffer,t|
|00003130| 65 6d 70 62 79 74 65 29 | 00 20 20 20 20 20 20 20 |empbyte)|. |
|00003140| 20 20 20 20 20 20 20 73 | 62 75 66 66 65 72 3d dc | s|buffer=.|
|00003150| 92 28 73 62 75 66 66 65 | 72 2c 33 32 29 00 20 20 |.(sbuffe|r,32). |
|00003160| 20 20 20 20 20 20 20 20 | 20 20 80 c0 00 20 20 20 | | ... |
|00003170| 20 20 20 20 20 20 20 20 | 20 74 65 6d 70 77 6f 72 | | tempwor|
|00003180| 64 3d 74 6f 74 61 6c 5f | 76 65 72 74 69 63 65 73 |d=total_|vertices|
|00003190| 2b 32 00 20 20 20 20 20 | 20 20 20 20 20 20 20 6e |+2. | n|
|000031a0| 75 6d 5f 76 65 72 74 69 | 63 65 73 3d bc 01 28 dc |um_verti|ces=..(.|
|000031b0| 81 28 73 62 75 66 66 65 | 72 2c dc 89 28 73 62 75 |.(sbuffe|r,..(sbu|
|000031c0| 66 66 65 72 2c 22 20 22 | 29 2d 31 29 29 00 20 20 |ffer," "|)-1)). |
|000031d0| 20 20 20 20 20 20 20 20 | 20 20 69 6e 64 65 78 2e | | index.|
|000031e0| 77 3d 6c 6e 2d 74 65 6d | 70 77 6f 72 64 00 20 20 |w=ln-tem|pword. |
|000031f0| 20 20 20 20 20 20 20 20 | 20 20 5c 70 6f 6c 79 73 | | \polys|
|00003200| 5b 69 6e 64 65 78 5d 5c | 6e 75 6d 70 6f 69 6e 74 |[index]\|numpoint|
|00003210| 73 3d 6e 75 6d 5f 76 65 | 72 74 69 63 65 73 00 20 |s=num_ve|rtices. |
|00003220| 20 20 20 20 20 20 20 20 | 20 20 20 5c 70 6f 6c 79 | | \poly|
|00003230| 73 5b 69 6e 64 65 78 5d | 5c 73 68 61 64 69 6e 67 |s[index]|\shading|
|00003240| 20 20 3d 63 6f 6c 6f 72 | 5f 64 65 73 20 80 7d 20 | =color|_des .} |
|00003250| 31 33 00 20 20 20 20 20 | 20 20 20 20 20 20 20 5c |13. | \|
|00003260| 70 6f 6c 79 73 5b 69 6e | 64 65 78 5d 5c 74 77 6f |polys[in|dex]\two|
|00003270| 73 69 64 65 64 20 3d 63 | 6f 6c 6f 72 5f 64 65 73 |sided =c|olor_des|
|00003280| 20 80 7d 20 31 32 00 20 | 20 20 20 20 20 20 20 20 | .} 12. | |
|00003290| 20 20 20 5c 70 6f 6c 79 | 73 5b 69 6e 64 65 78 5d | \poly|s[index]|
|000032a0| 5c 63 6f 6c 6f 72 20 20 | 20 20 3d 63 6f 6c 6f 72 |\color | =color|
|000032b0| 5f 64 65 73 20 80 cf 20 | 31 32 00 20 20 20 20 20 |_des .. |12. |
|000032c0| 20 20 20 20 20 20 20 5c | 70 6f 6c 79 73 5b 69 6e | \|polys[in|
|000032d0| 64 65 78 5d 5c 76 69 73 | 69 62 6c 65 20 20 3d 31 |dex]\vis|ible =1|
|000032e0| 00 20 20 20 20 20 20 20 | 20 20 20 20 20 5c 70 6f |. | \po|
|000032f0| 6c 79 73 5b 69 6e 64 65 | 78 5d 5c 63 6c 69 70 70 |lys[inde|x]\clipp|
|00003300| 65 64 20 20 3d 30 00 20 | 20 20 20 20 20 20 20 20 |ed =0. | |
|00003310| 20 20 20 5c 70 6f 6c 79 | 73 5b 69 6e 64 65 78 5d | \poly|s[index]|
|00003320| 5c 61 63 74 69 76 65 20 | 20 20 3d 31 00 20 20 20 |\active | =1. |
|00003330| 20 20 20 20 20 20 20 20 | 20 3b 65 78 74 72 61 63 | | ;extrac|
|00003340| 74 20 6e 75 6d 62 65 72 | 20 6f 66 20 76 65 72 74 |t number| of vert|
|00003350| 69 63 65 73 2e 2e 2e 00 | 20 20 20 20 20 20 20 20 |ices....| |
|00003360| 20 20 20 20 73 62 75 66 | 66 65 72 3d dc 91 28 73 | sbuf|fer=..(s|
|00003370| 62 75 66 66 65 72 2c dc | 89 28 73 62 75 66 66 65 |buffer,.|.(sbuffe|
|00003380| 72 2c 22 20 22 29 29 00 | 20 20 20 20 20 20 20 20 |r," ")).| |
|00003390| 20 20 20 20 73 62 75 66 | 66 65 72 3d dc 92 28 73 | sbuf|fer=..(s|
|000033a0| 62 75 66 66 65 72 2c 33 | 32 29 00 20 20 20 20 20 |buffer,3|2). |
|000033b0| 20 20 20 20 20 20 20 3b | 2e 2e 2e 61 6e 64 20 72 | ;|...and r|
|000033c0| 65 61 64 20 76 65 72 74 | 69 63 65 73 20 69 6e 74 |ead vert|ices int|
|000033d0| 6f 20 61 6e 20 6f 62 6a | 65 63 74 20 73 74 72 75 |o an obj|ect stru|
|000033e0| 63 74 75 72 65 00 20 20 | 20 20 20 20 20 20 20 20 |cture. | |
|000033f0| 20 20 80 16 20 69 3d 31 | 20 80 18 20 6e 75 6d 5f | .. i=1| .. num_|
|00003400| 76 65 72 74 69 63 65 73 | 2d 31 00 20 20 20 20 20 |vertices|-1. |
|00003410| 20 20 20 20 20 20 20 20 | 20 6b 2e 77 3d dc 89 28 | | k.w=..(|
|00003420| 73 62 75 66 66 65 72 2c | 22 20 22 29 00 20 20 20 |sbuffer,|" "). |
|00003430| 20 20 20 20 20 20 20 20 | 20 20 20 80 0b 20 dc 8f | | .. ..|
|00003440| 28 73 62 75 66 66 65 72 | 29 3d 31 20 80 21 20 6b |(sbuffer|)=1 .! k|
|00003450| 3d 32 00 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |=2. | |
|00003460| 20 74 2e 77 3d bc 01 28 | dc 81 28 73 62 75 66 66 | t.w=..(|..(sbuff|
|00003470| 65 72 2c 6b 2d 31 29 29 | 00 20 20 20 20 20 20 20 |er,k-1))|. |
|00003480| 20 20 20 20 20 20 20 73 | 62 75 66 66 65 72 3d dc | s|buffer=.|
|00003490| 91 28 73 62 75 66 66 65 | 72 2c 6b 29 00 20 20 20 |.(sbuffe|r,k). |
|000034a0| 20 20 20 20 20 20 20 20 | 20 20 20 73 62 75 66 66 | | sbuff|
|000034b0| 65 72 3d dc 92 28 73 62 | 75 66 66 65 72 2c 33 32 |er=..(sb|uffer,32|
|000034c0| 29 00 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |). | |
|000034d0| 5c 70 6f 6c 79 73 5b 69 | 6e 64 65 78 5d 5c 76 65 |\polys[i|ndex]\ve|
|000034e0| 72 74 65 78 6c 69 73 74 | 5b 69 2d 31 5d 3d 74 00 |rtexlist|[i-1]=t.|
|000034f0| 20 20 20 20 20 20 20 20 | 20 20 20 20 80 17 00 20 | | ... |
|00003500| 20 20 20 20 20 20 20 20 | 20 20 20 5c 70 6f 6c 79 | | \poly|
|00003510| 73 5b 69 6e 64 65 78 5d | 5c 76 65 72 74 65 78 6c |s[index]|\vertexl|
|00003520| 69 73 74 5b 6e 75 6d 5f | 76 65 72 74 69 63 65 73 |ist[num_|vertices|
|00003530| 2d 31 5d 3d bc 01 28 73 | 62 75 66 66 65 72 29 00 |-1]=..(s|buffer).|
|00003540| 00 20 20 20 20 20 20 20 | 20 20 20 20 20 3b 70 72 |. | ;pr|
|00003550| 65 63 6f 6d 70 75 74 65 | 20 6e 6f 72 6d 61 6c 73 |ecompute| normals|
|00003560| 2c 20 65 74 63 2e 2e 2e | 00 20 20 20 20 20 20 20 |, etc...|. |
|00003570| 20 20 20 20 20 76 65 72 | 74 65 78 5f 30 3d 5c 70 | ver|tex_0=\p|
|00003580| 6f 6c 79 73 5b 69 6e 64 | 65 78 5d 5c 76 65 72 74 |olys[ind|ex]\vert|
|00003590| 65 78 6c 69 73 74 5b 30 | 5d 00 20 20 20 20 20 20 |exlist[0|]. |
|000035a0| 20 20 20 20 20 20 76 65 | 72 74 65 78 5f 31 3d 5c | ve|rtex_1=\|
|000035b0| 70 6f 6c 79 73 5b 69 6e | 64 65 78 5d 5c 76 65 72 |polys[in|dex]\ver|
|000035c0| 74 65 78 6c 69 73 74 5b | 31 5d 00 20 20 20 20 20 |texlist[|1]. |
|000035d0| 20 20 20 20 20 20 20 76 | 65 72 74 65 78 5f 32 3d | v|ertex_2=|
|000035e0| 5c 70 6f 6c 79 73 5b 69 | 6e 64 65 78 5d 5c 76 65 |\polys[i|ndex]\ve|
|000035f0| 72 74 65 78 6c 69 73 74 | 5b 32 5d 00 00 20 20 20 |rtexlist|[2].. |
|00003600| 20 20 20 20 20 20 20 20 | 20 76 30 2e 76 65 72 74 | | v0.vert|
|00003610| 65 78 5c 78 3d 5c 76 6c | 6f 63 61 6c 5b 76 65 72 |ex\x=\vl|ocal[ver|
|00003620| 74 65 78 5f 30 5d 5c 78 | 2c 20 5c 76 6c 6f 63 61 |tex_0]\x|, \vloca|
|00003630| 6c 5b 76 65 72 74 65 78 | 5f 30 5d 5c 79 2c 20 5c |l[vertex|_0]\y, \|
|00003640| 76 6c 6f 63 61 6c 5b 76 | 65 72 74 65 78 5f 30 5d |vlocal[v|ertex_0]|
|00003650| 5c 7a 00 20 20 20 20 20 | 20 20 20 20 20 20 20 76 |\z. | v|
|00003660| 31 2e 76 65 72 74 65 78 | 5c 78 3d 5c 76 6c 6f 63 |1.vertex|\x=\vloc|
|00003670| 61 6c 5b 76 65 72 74 65 | 78 5f 31 5d 5c 78 2c 20 |al[verte|x_1]\x, |
|00003680| 5c 76 6c 6f 63 61 6c 5b | 76 65 72 74 65 78 5f 31 |\vlocal[|vertex_1|
|00003690| 5d 5c 79 2c 20 5c 76 6c | 6f 63 61 6c 5b 76 65 72 |]\y, \vl|ocal[ver|
|000036a0| 74 65 78 5f 31 5d 5c 7a | 00 20 20 20 20 20 20 20 |tex_1]\z|. |
|000036b0| 20 20 20 20 20 76 32 2e | 76 65 72 74 65 78 5c 78 | v2.|vertex\x|
|000036c0| 3d 5c 76 6c 6f 63 61 6c | 5b 76 65 72 74 65 78 5f |=\vlocal|[vertex_|
|000036d0| 32 5d 5c 78 2c 20 5c 76 | 6c 6f 63 61 6c 5b 76 65 |2]\x, \v|local[ve|
|000036e0| 72 74 65 78 5f 32 5d 5c | 79 2c 20 5c 76 6c 6f 63 |rtex_2]\|y, \vloc|
|000036f0| 61 6c 5b 76 65 72 74 65 | 78 5f 32 5d 5c 7a 00 00 |al[verte|x_2]\z..|
|00003700| 20 20 20 20 20 20 20 20 | 20 20 20 20 4d 61 6b 65 | | Make|
|00003710| 56 65 63 74 6f 72 33 44 | 7b 76 30 2c 20 76 31 2c |Vector3D|{v0, v1,|
|00003720| 20 75 7d 00 20 20 20 20 | 20 20 20 20 20 20 20 20 | u}. | |
|00003730| 4d 61 6b 65 56 65 63 74 | 6f 72 33 44 7b 76 30 2c |MakeVect|or3D{v0,|
|00003740| 20 76 32 2c 20 76 7d 00 | 00 20 20 20 20 20 20 20 | v2, v}.|. |
|00003750| 20 20 20 20 20 43 72 6f | 73 73 50 72 6f 64 75 63 | Cro|ssProduc|
|00003760| 74 7b 75 2c 20 76 2c 20 | 6e 6f 72 6d 61 6c 7d 00 |t{u, v, |normal}.|
|00003770| 20 20 20 20 20 20 20 20 | 20 20 20 20 5c 70 6f 6c | | \pol|
|00003780| 79 73 5b 69 6e 64 65 78 | 5d 5c 6e 6f 72 6d 61 6c |ys[index|]\normal|
|00003790| 6c 65 6e 67 74 68 3d 56 | 65 63 74 6f 72 4d 61 67 |length=V|ectorMag|
|000037a0| 33 44 7b 6e 6f 72 6d 61 | 6c 7d 00 20 20 20 20 20 |3D{norma|l}. |
|000037b0| 20 20 20 20 20 20 20 80 | c0 00 20 20 20 20 20 20 | .|.. |
|000037c0| 20 20 20 20 80 c0 00 20 | 20 20 20 20 20 20 20 80 | ... | .|
|000037d0| c0 00 20 20 20 20 20 20 | 80 c0 00 20 20 20 20 20 |.. |... |
|000037e0| 20 be 0b 20 30 2c be 0c | 28 30 29 20 3b 61 64 76 | .. 0,..|(0) ;adv|
|000037f0| 61 6e 63 65 20 74 6f 20 | 74 68 65 20 6e 65 78 74 |ance to |the next|
|00003800| 20 6c 69 6e 65 20 69 6e | 20 50 4c 47 20 66 69 6c | line in| PLG fil|
|00003810| 65 00 20 20 20 20 80 c1 | 00 20 20 20 20 be 02 20 |e. ..|. .. |
|00003820| 30 00 20 20 20 20 43 6f | 6d 70 75 74 65 4f 62 6a |0. Co|mputeObj|
|00003830| 65 63 74 52 61 64 69 75 | 73 7b 7d 00 20 20 80 c0 |ectRadiu|s{}. ..|
|00003840| 00 80 c0 00 80 02 20 80 | 08 00 00 3b 2d 2d 2d 2d |...... .|...;----|
|00003850| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003860| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003870| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003880| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 00 2e 4f 62 6a 65 |--------|--..Obje|
|00003890| 63 74 50 72 69 6e 74 00 | 80 08 20 4f 62 6a 65 63 |ctPrint.|.. Objec|
|000038a0| 74 50 72 69 6e 74 7b 7d | 00 3b 20 50 72 69 6e 74 |tPrint{}|.; Print|
|000038b0| 73 20 6f 75 74 20 63 6f | 6e 74 65 6e 74 20 6f 66 |s out co|ntent of|
|000038c0| 20 61 6e 20 6f 62 6a 65 | 63 74 20 73 74 72 75 63 | an obje|ct struc|
|000038d0| 74 75 72 65 20 74 6f 20 | 64 65 66 61 75 6c 74 20 |ture to |default |
|000038e0| 6f 75 74 70 75 74 00 3b | 00 20 20 80 15 20 4f 42 |output.;|. .. OB|
|000038f0| 4a 45 43 54 53 28 29 00 | 20 20 80 ca 20 4f 42 4a |JECTS().| .. OBJ|
|00003900| 45 43 54 53 28 29 00 20 | 20 dd 82 20 22 49 44 3a |ECTS(). | .. "ID:|
|00003910| 20 22 2c 5c 69 64 3a dd | 82 20 22 4e 61 6d 65 3a | ",\id:.|. "Name:|
|00003920| 20 22 2c 5c 6e 61 6d 65 | 00 20 20 dd 82 20 22 4e | ",\name|. .. "N|
|00003930| 75 6d 62 65 72 20 6f 66 | 20 76 65 72 74 69 63 65 |umber of| vertice|
|00003940| 73 3a 20 22 2c 5c 6e 75 | 6d 76 65 72 74 73 00 20 |s: ",\nu|mverts. |
|00003950| 20 dd 82 20 22 4e 75 6d | 62 65 72 20 6f 66 20 70 | .. "Num|ber of p|
|00003960| 6f 6c 79 67 6f 6e 73 3a | 20 22 2c 5c 6e 75 6d 70 |olygons:| ",\nump|
|00003970| 6f 6c 79 73 00 20 20 dd | 82 20 22 53 74 61 74 65 |olys. .|. "State|
|00003980| 3a 20 22 2c 5c 73 74 61 | 74 65 00 20 20 dd 82 20 |: ",\sta|te. .. |
|00003990| 22 57 6f 72 6c 64 20 50 | 6f 73 69 74 69 6f 6e 3a |"World P|osition:|
|000039a0| 20 58 3d 22 2c 5c 77 6f | 72 6c 64 70 6f 73 5c 78 | X=",\wo|rldpos\x|
|000039b0| 00 20 20 dd 82 20 22 20 | 20 20 20 20 20 20 20 20 |. .. " | |
|000039c0| 20 20 20 20 20 20 20 59 | 3d 22 2c 5c 77 6f 72 6c | Y|=",\worl|
|000039d0| 64 70 6f 73 5c 79 00 20 | 20 dd 82 20 22 20 20 20 |dpos\y. | .. " |
|000039e0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 5a 3d 22 | | Z="|
|000039f0| 2c 5c 77 6f 72 6c 64 70 | 6f 73 5c 7a 00 20 20 dd |,\worldp|os\z. .|
|00003a00| 82 20 22 4f 62 6a 65 63 | 74 27 73 20 72 61 64 69 |. "Objec|t's radi|
|00003a10| 75 73 3a 20 22 2c 5c 72 | 61 64 69 75 73 00 20 20 |us: ",\r|adius. |
|00003a20| dd 82 20 22 4c 6f 63 61 | 6c 20 56 65 72 74 69 63 |.. "Loca|l Vertic|
|00003a30| 65 73 3a 22 00 20 20 dd | 84 20 22 2d 23 23 23 2e |es:". .|. "-###.|
|00003a40| 30 23 23 23 23 23 22 00 | 20 20 80 16 20 6b 3d 30 |0#####".| .. k=0|
|00003a50| 20 80 18 20 5c 6e 75 6d | 76 65 72 74 73 2d 31 00 | .. \num|verts-1.|
|00003a60| 20 20 20 20 dd 82 20 5c | 76 6c 6f 63 61 6c 5b 6b | .. \|vlocal[k|
|00003a70| 5d 5c 78 2c 22 20 22 2c | 5c 76 6c 6f 63 61 6c 5b |]\x," ",|\vlocal[|
|00003a80| 6b 5d 5c 79 2c 22 20 22 | 2c 5c 76 6c 6f 63 61 6c |k]\y," "|,\vlocal|
|00003a90| 5b 6b 5d 5c 7a 00 20 20 | 80 17 00 20 20 dd 82 20 |[k]\z. |... .. |
|00003aa0| 22 47 6c 6f 62 61 6c 20 | 56 65 72 74 69 63 65 73 |"Global |Vertices|
|00003ab0| 3a 22 00 20 20 80 16 20 | 6b 3d 30 20 80 18 20 5c |:". .. |k=0 .. \|
|00003ac0| 6e 75 6d 76 65 72 74 73 | 2d 31 00 20 20 20 20 dd |numverts|-1. .|
|00003ad0| 82 20 5c 76 67 6c 6f 62 | 61 6c 5b 6b 5d 5c 78 2c |. \vglob|al[k]\x,|
|00003ae0| 22 20 22 2c 5c 76 67 6c | 6f 62 61 6c 5b 6b 5d 5c |" ",\vgl|obal[k]\|
|00003af0| 79 2c 22 20 22 2c 5c 76 | 67 6c 6f 62 61 6c 5b 6b |y," ",\v|global[k|
|00003b00| 5d 5c 7a 00 20 20 80 17 | 00 20 20 dd 82 20 22 43 |]\z. ..|. .. "C|
|00003b10| 61 6d 65 72 61 20 56 65 | 72 74 69 63 65 73 3a 22 |amera Ve|rtices:"|
|00003b20| 00 20 20 80 16 20 6b 3d | 30 20 80 18 20 5c 6e 75 |. .. k=|0 .. \nu|
|00003b30| 6d 76 65 72 74 73 2d 31 | 00 20 20 20 20 dd 82 20 |mverts-1|. .. |
|00003b40| 5c 76 63 61 6d 65 72 61 | 5b 6b 5d 5c 78 2c 22 20 |\vcamera|[k]\x," |
|00003b50| 22 2c 5c 76 63 61 6d 65 | 72 61 5b 6b 5d 5c 79 2c |",\vcame|ra[k]\y,|
|00003b60| 22 20 22 2c 5c 76 63 61 | 6d 65 72 61 5b 6b 5d 5c |" ",\vca|mera[k]\|
|00003b70| 7a 00 20 20 80 17 00 20 | 20 dd 84 20 22 22 00 20 |z. ... | .. "". |
|00003b80| 20 dd 82 20 22 22 3a dd | 82 20 22 50 6f 6c 79 67 | .. "":.|. "Polyg|
|00003b90| 6f 6e 73 20 6c 69 73 74 | 3a 22 3a dd 82 20 22 22 |ons list|:":.. ""|
|00003ba0| 00 20 20 80 16 20 69 3d | 30 20 80 18 20 5c 6e 75 |. .. i=|0 .. \nu|
|00003bb0| 6d 70 6f 6c 79 73 2d 31 | 00 20 20 dd 82 20 22 50 |mpolys-1|. .. "P|
|00003bc0| 6f 6c 79 67 6f 6e 22 2c | 69 2c 22 3a 20 22 00 20 |olygon",|i,": ". |
|00003bd0| 20 80 16 20 6a 3d 30 20 | 80 18 20 5c 70 6f 6c 79 | .. j=0 |.. \poly|
|00003be0| 73 5b 69 5d 5c 6e 75 6d | 70 6f 69 6e 74 73 2d 31 |s[i]\num|points-1|
|00003bf0| 00 20 20 20 20 dd 81 20 | 5c 70 6f 6c 79 73 5b 69 |. .. |\polys[i|
|00003c00| 5d 5c 76 65 72 74 65 78 | 6c 69 73 74 5b 6a 5d 2c |]\vertex|list[j],|
|00003c10| 22 20 22 00 20 20 80 17 | 00 20 20 dd 81 20 22 20 |" ". ..|. .. " |
|00003c20| 63 6f 6c 6f 72 3a 22 2c | 5c 70 6f 6c 79 73 5b 69 |color:",|\polys[i|
|00003c30| 5d 5c 63 6f 6c 6f 72 2c | 22 20 73 68 61 64 65 3a |]\color,|" shade:|
|00003c40| 22 2c 5c 70 6f 6c 79 73 | 5b 69 5d 5c 73 68 61 64 |",\polys|[i]\shad|
|00003c50| 65 2c 22 20 73 68 61 64 | 69 6e 67 3a 22 2c 5c 70 |e," shad|ing:",\p|
|00003c60| 6f 6c 79 73 5b 69 5d 5c | 73 68 61 64 69 6e 67 2c |olys[i]\|shading,|
|00003c70| 22 20 32 2d 73 69 64 65 | 64 3a 22 2c 5c 70 6f 6c |" 2-side|d:",\pol|
|00003c80| 79 73 5b 69 5d 5c 74 77 | 6f 73 69 64 65 64 00 20 |ys[i]\tw|osided. |
|00003c90| 20 dd 82 20 22 20 76 69 | 73 69 62 6c 65 3a 22 2c | .. " vi|sible:",|
|00003ca0| 5c 70 6f 6c 79 73 5b 69 | 5d 5c 76 69 73 69 62 6c |\polys[i|]\visibl|
|00003cb0| 65 2c 22 20 63 6c 69 70 | 70 65 64 3a 22 2c 5c 70 |e," clip|ped:",\p|
|00003cc0| 6f 6c 79 73 5b 69 5d 5c | 63 6c 69 70 70 65 64 2c |olys[i]\|clipped,|
|00003cd0| 22 20 61 63 74 69 76 65 | 3a 22 2c 5c 70 6f 6c 79 |" active|:",\poly|
|00003ce0| 73 5b 69 5d 5c 61 63 74 | 69 76 65 00 20 20 dd 82 |s[i]\act|ive. ..|
|00003cf0| 20 22 54 68 69 73 20 70 | 6f 6c 79 73 20 4e 6f 72 | "This p|olys Nor|
|00003d00| 6d 61 6c 20 6c 65 6e 67 | 74 68 3d 22 2c 5c 70 6f |mal leng|th=",\po|
|00003d10| 6c 79 73 5b 69 5d 5c 6e | 6f 72 6d 61 6c 6c 65 6e |lys[i]\n|ormallen|
|00003d20| 67 74 68 00 20 20 dd 82 | 20 22 22 00 20 20 80 17 |gth. ..| "". ..|
|00003d30| 00 80 02 20 80 08 00 00 | 3b 2d 2d 2d 2d 2d 2d 2d |... ....|;-------|
|00003d40| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003d50| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003d60| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003d70| 2d 2d 2d 2d 2d 2d 2d 00 | 2e 54 72 61 6e 73 6c 61 |-------.|.Transla|
|00003d80| 74 65 4f 62 6a 65 63 74 | 00 80 08 20 54 72 61 6e |teObject|... Tran|
|00003d90| 73 6c 61 74 65 4f 62 6a | 65 63 74 7b 64 78 2e 6c |slateObj|ect{dx.l|
|00003da0| 2c 20 64 79 2e 6c 2c 20 | 64 7a 2e 6c 7d 00 3b 20 |, dy.l, |dz.l}.; |
|00003db0| 54 72 61 6e 73 6c 61 74 | 65 73 20 61 6e 20 6f 62 |Translat|es an ob|
|00003dc0| 6a 65 63 74 20 72 65 6c | 61 74 69 76 65 20 74 6f |ject rel|ative to|
|00003dd0| 20 69 74 73 20 6f 77 6e | 20 6c 6f 63 61 6c 20 63 | its own| local c|
|00003de0| 6f 6f 72 64 69 6e 61 74 | 65 73 00 3b 00 20 20 80 |oordinat|es.;. .|
|00003df0| 15 20 4f 42 4a 45 43 54 | 53 28 29 00 20 20 80 ca |. OBJECT|S(). ..|
|00003e00| 20 4f 42 4a 45 43 54 53 | 28 29 00 20 20 5c 77 6f | OBJECTS|(). \wo|
|00003e10| 72 6c 64 70 6f 73 5c 78 | 2b 64 78 00 20 20 5c 77 |rldpos\x|+dx. \w|
|00003e20| 6f 72 6c 64 70 6f 73 5c | 79 2b 64 79 00 20 20 5c |orldpos\|y+dy. \|
|00003e30| 77 6f 72 6c 64 70 6f 73 | 5c 7a 2b 64 7a 00 80 02 |worldpos|\z+dz...|
|00003e40| 20 80 08 00 00 3b 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d | ....;--|--------|
|00003e50| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003e60| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003e70| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003e80| 2d 2d 2d 2d 00 2e 50 6f | 73 69 74 69 6f 6e 4f 62 |----..Po|sitionOb|
|00003e90| 6a 65 63 74 00 80 08 20 | 50 6f 73 69 74 69 6f 6e |ject... |Position|
|00003ea0| 4f 62 6a 65 63 74 7b 78 | 2e 6c 2c 20 79 2e 6c 2c |Object{x|.l, y.l,|
|00003eb0| 20 7a 2e 6c 7d 00 3b 20 | 50 6f 73 69 74 69 6f 6e | z.l}.; |Position|
|00003ec0| 20 61 6e 20 6f 62 6a 65 | 63 74 20 69 6e 20 74 68 | an obje|ct in th|
|00003ed0| 65 20 33 64 20 77 6f 72 | 6c 64 00 3b 00 20 20 80 |e 3d wor|ld.;. .|
|00003ee0| 15 20 4f 42 4a 45 43 54 | 53 28 29 00 20 20 80 ca |. OBJECT|S(). ..|
|00003ef0| 20 4f 42 4a 45 43 54 53 | 28 29 00 20 20 5c 77 6f | OBJECTS|(). \wo|
|00003f00| 72 6c 64 70 6f 73 5c 78 | 3d 78 00 20 20 5c 77 6f |rldpos\x|=x. \wo|
|00003f10| 72 6c 64 70 6f 73 5c 79 | 3d 79 00 20 20 5c 77 6f |rldpos\y|=y. \wo|
|00003f20| 72 6c 64 70 6f 73 5c 7a | 3d 7a 00 80 02 20 80 08 |rldpos\z|=z... ..|
|00003f30| 00 00 3b 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |..;-----|--------|
|00003f40| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003f50| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003f60| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003f70| 2d 00 2e 53 63 61 6c 65 | 4f 62 6a 65 63 74 00 80 |-..Scale|Object..|
|00003f80| 08 20 53 63 61 6c 65 4f | 62 6a 65 63 74 7b 73 63 |. ScaleO|bject{sc|
|00003f90| 61 6c 65 5f 66 61 63 74 | 6f 72 2e 66 7d 00 3b 20 |ale_fact|or.f}.; |
|00003fa0| 53 63 61 6c 65 73 20 61 | 6e 20 6f 62 6a 65 63 74 |Scales a|n object|
|00003fb0| 20 62 79 20 61 20 66 61 | 63 74 6f 72 20 72 65 6c | by a fa|ctor rel|
|00003fc0| 61 74 69 76 65 20 74 6f | 20 6c 6f 63 61 6c 20 63 |ative to| local c|
|00003fd0| 6f 6f 72 64 69 6e 61 74 | 65 73 2e 00 3b 00 20 20 |oordinat|es..;. |
|00003fe0| 80 15 20 4f 42 4a 45 43 | 54 53 28 29 00 20 20 80 |.. OBJEC|TS(). .|
|00003ff0| 33 2e 6c 20 63 75 72 72 | 5f 70 6f 6c 79 2c 20 63 |3.l curr|_poly, c|
|00004000| 75 72 72 5f 76 65 72 74 | 65 78 00 20 20 80 33 2e |urr_vert|ex. .3.|
|00004010| 66 20 73 63 61 6c 65 5f | 32 00 20 20 80 ca 20 4f |f scale_|2. .. O|
|00004020| 42 4a 45 43 54 53 28 29 | 00 00 20 20 80 16 20 63 |BJECTS()|.. .. c|
|00004030| 75 72 72 5f 76 65 72 74 | 65 78 3d 30 20 80 18 20 |urr_vert|ex=0 .. |
|00004040| 5c 6e 75 6d 76 65 72 74 | 73 00 20 20 20 20 5c 76 |\numvert|s. \v|
|00004050| 6c 6f 63 61 6c 5b 63 75 | 72 72 5f 76 65 72 74 65 |local[cu|rr_verte|
|00004060| 78 5d 5c 78 20 2a 20 73 | 63 61 6c 65 5f 66 61 63 |x]\x * s|cale_fac|
|00004070| 74 6f 72 00 20 20 20 20 | 5c 76 6c 6f 63 61 6c 5b |tor. |\vlocal[|
|00004080| 63 75 72 72 5f 76 65 72 | 74 65 78 5d 5c 79 20 2a |curr_ver|tex]\y *|
|00004090| 20 73 63 61 6c 65 5f 66 | 61 63 74 6f 72 00 20 20 | scale_f|actor. |
|000040a0| 20 20 5c 76 6c 6f 63 61 | 6c 5b 63 75 72 72 5f 76 | \vloca|l[curr_v|
|000040b0| 65 72 74 65 78 5d 5c 7a | 20 2a 20 73 63 61 6c 65 |ertex]\z| * scale|
|000040c0| 5f 66 61 63 74 6f 72 00 | 20 20 80 17 20 63 75 72 |_factor.| .. cur|
|000040d0| 72 5f 76 65 72 74 65 78 | 00 00 20 20 73 63 61 6c |r_vertex|.. scal|
|000040e0| 65 5f 32 20 3d 20 73 63 | 61 6c 65 5f 66 61 63 74 |e_2 = sc|ale_fact|
|000040f0| 6f 72 5e 32 00 20 20 80 | 16 20 63 75 72 72 5f 70 |or^2. .|. curr_p|
|00004100| 6f 6c 79 3d 30 20 80 18 | 20 5c 6e 75 6d 70 6f 6c |oly=0 ..| \numpol|
|00004110| 79 73 00 20 20 20 20 5c | 70 6f 6c 79 73 5b 63 75 |ys. \|polys[cu|
|00004120| 72 72 5f 70 6f 6c 79 5d | 5c 6e 6f 72 6d 61 6c 6c |rr_poly]|\normall|
|00004130| 65 6e 67 74 68 20 2a 20 | 73 63 61 6c 65 5f 32 00 |ength * |scale_2.|
|00004140| 20 20 80 17 20 63 75 72 | 72 5f 70 6f 6c 79 00 00 | .. cur|r_poly..|
|00004150| 20 20 5c 72 61 64 69 75 | 73 20 2a 20 73 63 61 6c | \radiu|s * scal|
|00004160| 65 5f 66 61 63 74 6f 72 | 00 80 02 20 80 08 00 00 |e_factor|... ....|
|00004170| 3b 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |;-------|--------|
|00004180| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004190| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000041a0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 00 |--------|-------.|
|000041b0| 2e 52 6f 74 61 74 65 4f | 62 6a 65 63 74 00 80 08 |.RotateO|bject...|
|000041c0| 20 52 6f 74 61 74 65 4f | 62 6a 65 63 74 7b 61 6e | RotateO|bject{an|
|000041d0| 67 6c 65 5f 78 2e 77 2c | 20 61 6e 67 6c 65 5f 79 |gle_x.w,| angle_y|
|000041e0| 2e 77 2c 20 70 61 64 2e | 6c 2c 20 61 6e 67 6c 65 |.w, pad.|l, angle|
|000041f0| 5f 7a 2e 77 7d 00 3b 20 | 52 6f 74 61 74 65 73 20 |_z.w}.; |Rotates |
|00004200| 61 6e 20 6f 62 6a 65 63 | 74 20 61 72 6f 75 6e 64 |an objec|t around|
|00004210| 20 69 74 73 20 6c 6f 63 | 61 6c 20 63 6f 6f 72 64 | its loc|al coord|
|00004220| 69 6e 61 74 65 20 73 79 | 73 74 65 6d 2c 00 3b 20 |inate sy|stem,.; |
|00004230| 61 6c 6c 6f 77 69 6e 67 | 20 73 69 6d 75 6c 74 61 |allowing| simulta|
|00004240| 6e 65 6f 75 73 20 72 6f | 74 61 74 69 6f 6e 73 2e |neous ro|tations.|
|00004250| 00 3b 00 20 20 80 15 20 | 53 49 4e 54 41 42 4c 45 |.;. .. |SINTABLE|
|00004260| 28 29 2c 20 43 4f 53 54 | 41 42 4c 45 28 29 2c 20 |(), COST|ABLE(), |
|00004270| 4f 42 4a 45 43 54 53 28 | 29 00 20 20 80 33 2e 6c |OBJECTS(|). .3.l|
|00004280| 20 69 2c 20 70 72 6f 64 | 75 63 74 00 20 20 80 33 | i, prod|uct. .3|
|00004290| 2e 6d 61 74 72 69 78 34 | 78 34 20 72 6f 74 61 74 |.matrix4|x4 rotat|
|000042a0| 65 5f 78 2c 20 72 6f 74 | 61 74 65 5f 79 2c 20 72 |e_x, rot|ate_y, r|
|000042b0| 6f 74 61 74 65 5f 7a 2c | 20 72 6f 74 2c 20 74 65 |otate_z,| rot, te|
|000042c0| 6d 70 00 20 20 80 33 2e | 66 20 74 65 6d 70 5f 78 |mp. .3.|f temp_x|
|000042d0| 2c 20 74 65 6d 70 5f 79 | 2c 20 74 65 6d 70 5f 7a |, temp_y|, temp_z|
|000042e0| 00 00 20 20 3b 63 68 65 | 63 6b 20 69 66 20 6e 65 |.. ;che|ck if ne|
|000042f0| 65 64 20 74 6f 20 72 6f | 74 61 74 65 20 61 74 20 |ed to ro|tate at |
|00004300| 61 6c 6c 00 20 20 80 0b | 20 61 6e 67 6c 65 5f 78 |all. ..| angle_x|
|00004310| 3d 30 20 80 42 20 61 6e | 67 6c 65 5f 79 3d 30 20 |=0 .B an|gle_y=0 |
|00004320| 80 42 20 61 6e 67 6c 65 | 5f 7a 3d 30 20 80 21 20 |.B angle|_z=0 .! |
|00004330| 80 08 20 80 07 00 00 20 | 20 80 ca 20 4f 42 4a 45 |.. .... | .. OBJE|
|00004340| 43 54 53 28 29 00 20 20 | 70 72 6f 64 75 63 74 3d |CTS(). |product=|
|00004350| 30 00 00 20 20 3b 63 72 | 65 61 74 65 20 69 64 65 |0.. ;cr|eate ide|
|00004360| 6e 74 69 74 79 20 6d 61 | 74 72 69 78 00 20 20 4d |ntity ma|trix. M|
|00004370| 61 74 49 64 65 6e 74 69 | 74 79 34 78 34 7b 72 6f |atIdenti|ty4x4{ro|
|00004380| 74 7d 00 00 20 20 80 0b | 20 28 61 6e 67 6c 65 5f |t}.. ..| (angle_|
|00004390| 78 3c 3e 30 29 20 80 21 | 20 70 72 6f 64 75 63 74 |x<>0) .!| product|
|000043a0| 2b 34 00 20 20 80 0b 20 | 28 61 6e 67 6c 65 5f 79 |+4. .. |(angle_y|
|000043b0| 3c 3e 30 29 20 80 21 20 | 70 72 6f 64 75 63 74 2b |<>0) .! |product+|
|000043c0| 32 00 20 20 80 0b 20 28 | 61 6e 67 6c 65 5f 7a 3c |2. .. (|angle_z<|
|000043d0| 3e 30 29 20 80 21 20 70 | 72 6f 64 75 63 74 2b 31 |>0) .! p|roduct+1|
|000043e0| 00 00 20 20 80 0e 20 70 | 72 6f 64 75 63 74 00 20 |.. .. p|roduct. |
|000043f0| 20 20 20 80 0f 20 31 00 | 20 20 20 20 20 20 72 6f | .. 1.| ro|
|00004400| 74 5c 72 30 5b 30 5d 3d | 20 28 20 43 4f 53 54 41 |t\r0[0]=| ( COSTA|
|00004410| 42 4c 45 28 61 6e 67 6c | 65 5f 7a 29 29 00 20 20 |BLE(angl|e_z)). |
|00004420| 20 20 20 20 72 6f 74 5c | 72 30 5b 31 5d 3d 20 28 | rot\|r0[1]= (|
|00004430| 20 53 49 4e 54 41 42 4c | 45 28 61 6e 67 6c 65 5f | SINTABL|E(angle_|
|00004440| 7a 29 29 00 20 20 20 20 | 20 20 72 6f 74 5c 72 31 |z)). | rot\r1|
|00004450| 5b 30 5d 3d 20 28 2d 53 | 49 4e 54 41 42 4c 45 28 |[0]= (-S|INTABLE(|
|00004460| 61 6e 67 6c 65 5f 7a 29 | 29 00 20 20 20 20 20 20 |angle_z)|). |
|00004470| 72 6f 74 5c 72 31 5b 31 | 5d 3d 20 28 20 43 4f 53 |rot\r1[1|]= ( COS|
|00004480| 54 41 42 4c 45 28 61 6e | 67 6c 65 5f 7a 29 29 00 |TABLE(an|gle_z)).|
|00004490| 20 20 20 20 20 20 80 16 | 20 69 3d 30 20 80 18 20 | ..| i=0 .. |
|000044a0| 5c 6e 75 6d 76 65 72 74 | 73 00 20 20 20 20 20 20 |\numvert|s. |
|000044b0| 20 20 74 65 6d 70 5f 78 | 3d 5c 76 6c 6f 63 61 6c | temp_x|=\vlocal|
|000044c0| 5b 69 5d 5c 78 2a 72 6f | 74 5c 72 30 5b 30 5d 2b |[i]\x*ro|t\r0[0]+|
|000044d0| 5c 76 6c 6f 63 61 6c 5b | 69 5d 5c 79 2a 72 6f 74 |\vlocal[|i]\y*rot|
|000044e0| 5c 72 31 5b 30 5d 00 20 | 20 20 20 20 20 20 20 74 |\r1[0]. | t|
|000044f0| 65 6d 70 5f 79 3d 5c 76 | 6c 6f 63 61 6c 5b 69 5d |emp_y=\v|local[i]|
|00004500| 5c 78 2a 72 6f 74 5c 72 | 30 5b 31 5d 2b 5c 76 6c |\x*rot\r|0[1]+\vl|
|00004510| 6f 63 61 6c 5b 69 5d 5c | 79 2a 72 6f 74 5c 72 31 |ocal[i]\|y*rot\r1|
|00004520| 5b 31 5d 00 20 20 20 20 | 20 20 20 20 74 65 6d 70 |[1]. | temp|
|00004530| 5f 7a 3d 5c 76 6c 6f 63 | 61 6c 5b 69 5d 5c 7a 00 |_z=\vloc|al[i]\z.|
|00004540| 20 20 20 20 20 20 20 20 | 5c 76 6c 6f 63 61 6c 5b | |\vlocal[|
|00004550| 69 5d 5c 78 3d 74 65 6d | 70 5f 78 00 20 20 20 20 |i]\x=tem|p_x. |
|00004560| 20 20 20 20 5c 76 6c 6f | 63 61 6c 5b 69 5d 5c 79 | \vlo|cal[i]\y|
|00004570| 3d 74 65 6d 70 5f 79 00 | 20 20 20 20 20 20 20 20 |=temp_y.| |
|00004580| 5c 76 6c 6f 63 61 6c 5b | 69 5d 5c 7a 3d 74 65 6d |\vlocal[|i]\z=tem|
|00004590| 70 5f 7a 00 20 20 20 20 | 20 20 80 17 20 69 00 20 |p_z. | .. i. |
|000045a0| 20 20 20 80 0f 20 32 00 | 20 20 20 20 20 20 72 6f | .. 2.| ro|
|000045b0| 74 5c 72 30 5b 30 5d 3d | 20 28 20 43 4f 53 54 41 |t\r0[0]=| ( COSTA|
|000045c0| 42 4c 45 28 61 6e 67 6c | 65 5f 79 29 29 00 20 20 |BLE(angl|e_y)). |
|000045d0| 20 20 20 20 72 6f 74 5c | 72 30 5b 32 5d 3d 20 28 | rot\|r0[2]= (|
|000045e0| 2d 53 49 4e 54 41 42 4c | 45 28 61 6e 67 6c 65 5f |-SINTABL|E(angle_|
|000045f0| 79 29 29 00 20 20 20 20 | 20 20 72 6f 74 5c 72 32 |y)). | rot\r2|
|00004600| 5b 30 5d 3d 20 28 20 53 | 49 4e 54 41 42 4c 45 28 |[0]= ( S|INTABLE(|
|00004610| 61 6e 67 6c 65 5f 79 29 | 29 00 20 20 20 20 20 20 |angle_y)|). |
|00004620| 72 6f 74 5c 72 32 5b 32 | 5d 3d 20 28 20 43 4f 53 |rot\r2[2|]= ( COS|
|00004630| 54 41 42 4c 45 28 61 6e | 67 6c 65 5f 79 29 29 00 |TABLE(an|gle_y)).|
|00004640| 20 20 20 20 20 20 80 16 | 20 69 3d 30 20 80 18 20 | ..| i=0 .. |
|00004650| 5c 6e 75 6d 76 65 72 74 | 73 00 20 20 20 20 20 20 |\numvert|s. |
|00004660| 20 20 74 65 6d 70 5f 78 | 3d 5c 76 6c 6f 63 61 6c | temp_x|=\vlocal|
|00004670| 5b 69 5d 5c 78 2a 72 6f | 74 5c 72 30 5b 30 5d 2b |[i]\x*ro|t\r0[0]+|
|00004680| 5c 76 6c 6f 63 61 6c 5b | 69 5d 5c 7a 2a 72 6f 74 |\vlocal[|i]\z*rot|
|00004690| 5c 72 32 5b 30 5d 00 20 | 20 20 20 20 20 20 20 74 |\r2[0]. | t|
|000046a0| 65 6d 70 5f 79 3d 5c 76 | 6c 6f 63 61 6c 5b 69 5d |emp_y=\v|local[i]|
|000046b0| 5c 79 00 20 20 20 20 20 | 20 20 20 74 65 6d 70 5f |\y. | temp_|
|000046c0| 7a 3d 5c 76 6c 6f 63 61 | 6c 5b 69 5d 5c 78 2a 72 |z=\vloca|l[i]\x*r|
|000046d0| 6f 74 5c 72 30 5b 32 5d | 2b 5c 76 6c 6f 63 61 6c |ot\r0[2]|+\vlocal|
|000046e0| 5b 69 5d 5c 7a 2a 72 6f | 74 5c 72 32 5b 32 5d 00 |[i]\z*ro|t\r2[2].|
|000046f0| 20 20 20 20 20 20 20 20 | 5c 76 6c 6f 63 61 6c 5b | |\vlocal[|
|00004700| 69 5d 5c 78 3d 74 65 6d | 70 5f 78 00 20 20 20 20 |i]\x=tem|p_x. |
|00004710| 20 20 20 20 5c 76 6c 6f | 63 61 6c 5b 69 5d 5c 79 | \vlo|cal[i]\y|
|00004720| 3d 74 65 6d 70 5f 79 00 | 20 20 20 20 20 20 20 20 |=temp_y.| |
|00004730| 5c 76 6c 6f 63 61 6c 5b | 69 5d 5c 7a 3d 74 65 6d |\vlocal[|i]\z=tem|
|00004740| 70 5f 7a 00 20 20 20 20 | 20 20 80 17 20 69 00 20 |p_z. | .. i. |
|00004750| 20 20 20 80 0f 20 33 00 | 20 20 20 20 20 20 72 6f | .. 3.| ro|
|00004760| 74 5c 72 30 5b 30 5d 3d | 20 43 4f 53 54 41 42 4c |t\r0[0]=| COSTABL|
|00004770| 45 28 61 6e 67 6c 65 5f | 79 29 2a 43 4f 53 54 41 |E(angle_|y)*COSTA|
|00004780| 42 4c 45 28 61 6e 67 6c | 65 5f 7a 29 00 20 20 20 |BLE(angl|e_z). |
|00004790| 20 20 20 72 6f 74 5c 72 | 30 5b 31 5d 3d 20 43 4f | rot\r|0[1]= CO|
|000047a0| 53 54 41 42 4c 45 28 61 | 6e 67 6c 65 5f 79 29 2a |STABLE(a|ngle_y)*|
|000047b0| 53 49 4e 54 41 42 4c 45 | 28 61 6e 67 6c 65 5f 7a |SINTABLE|(angle_z|
|000047c0| 29 00 20 20 20 20 20 20 | 72 6f 74 5c 72 30 5b 32 |). |rot\r0[2|
|000047d0| 5d 3d 2d 53 49 4e 54 41 | 42 4c 45 28 61 6e 67 6c |]=-SINTA|BLE(angl|
|000047e0| 65 5f 79 29 00 20 20 20 | 20 20 20 72 6f 74 5c 72 |e_y). | rot\r|
|000047f0| 31 5b 30 5d 3d 2d 53 49 | 4e 54 41 42 4c 45 28 61 |1[0]=-SI|NTABLE(a|
|00004800| 6e 67 6c 65 5f 7a 29 00 | 20 20 20 20 20 20 72 6f |ngle_z).| ro|
|00004810| 74 5c 72 31 5b 31 5d 3d | 20 43 4f 53 54 41 42 4c |t\r1[1]=| COSTABL|
|00004820| 45 28 61 6e 67 6c 65 5f | 7a 29 00 20 20 20 20 20 |E(angle_|z). |
|00004830| 20 72 6f 74 5c 72 32 5b | 30 5d 3d 20 53 49 4e 54 | rot\r2[|0]= SINT|
|00004840| 41 42 4c 45 28 61 6e 67 | 6c 65 5f 79 29 2a 43 4f |ABLE(ang|le_y)*CO|
|00004850| 53 54 41 42 4c 45 28 61 | 6e 67 6c 65 5f 7a 29 00 |STABLE(a|ngle_z).|
|00004860| 20 20 20 20 20 20 72 6f | 74 5c 72 32 5b 31 5d 3d | ro|t\r2[1]=|
|00004870| 20 53 49 4e 54 41 42 4c | 45 28 61 6e 67 6c 65 5f | SINTABL|E(angle_|
|00004880| 79 29 2a 53 49 4e 54 41 | 42 4c 45 28 61 6e 67 6c |y)*SINTA|BLE(angl|
|00004890| 65 5f 7a 29 00 20 20 20 | 20 20 20 72 6f 74 5c 72 |e_z). | rot\r|
|000048a0| 32 5b 32 5d 3d 20 43 4f | 53 54 41 42 4c 45 28 61 |2[2]= CO|STABLE(a|
|000048b0| 6e 67 6c 65 5f 79 29 00 | 20 20 20 20 20 20 80 16 |ngle_y).| ..|
|000048c0| 20 69 3d 30 20 80 18 20 | 5c 6e 75 6d 76 65 72 74 | i=0 .. |\numvert|
|000048d0| 73 00 20 20 20 20 20 20 | 20 20 74 65 6d 70 5f 78 |s. | temp_x|
|000048e0| 3d 5c 76 6c 6f 63 61 6c | 5b 69 5d 5c 78 2a 72 6f |=\vlocal|[i]\x*ro|
|000048f0| 74 5c 72 30 5b 30 5d 20 | 2b 20 5c 76 6c 6f 63 61 |t\r0[0] |+ \vloca|
|00004900| 6c 5b 69 5d 5c 79 2a 72 | 6f 74 5c 72 31 5b 30 5d |l[i]\y*r|ot\r1[0]|
|00004910| 20 2b 20 5c 76 6c 6f 63 | 61 6c 5b 69 5d 5c 7a 2a | + \vloc|al[i]\z*|
|00004920| 72 6f 74 5c 72 32 5b 30 | 5d 00 20 20 20 20 20 20 |rot\r2[0|]. |
|00004930| 20 20 74 65 6d 70 5f 79 | 3d 5c 76 6c 6f 63 61 6c | temp_y|=\vlocal|
|00004940| 5b 69 5d 5c 78 2a 72 6f | 74 5c 72 30 5b 31 5d 20 |[i]\x*ro|t\r0[1] |
|00004950| 2b 20 5c 76 6c 6f 63 61 | 6c 5b 69 5d 5c 79 2a 72 |+ \vloca|l[i]\y*r|
|00004960| 6f 74 5c 72 31 5b 31 5d | 20 2b 20 5c 76 6c 6f 63 |ot\r1[1]| + \vloc|
|00004970| 61 6c 5b 69 5d 5c 7a 2a | 72 6f 74 5c 72 32 5b 31 |al[i]\z*|rot\r2[1|
|00004980| 5d 00 20 20 20 20 20 20 | 20 20 74 65 6d 70 5f 7a |]. | temp_z|
|00004990| 3d 5c 76 6c 6f 63 61 6c | 5b 69 5d 5c 78 2a 72 6f |=\vlocal|[i]\x*ro|
|000049a0| 74 5c 72 30 5b 32 5d 20 | 2b 20 5c 76 6c 6f 63 61 |t\r0[2] |+ \vloca|
|000049b0| 6c 5b 69 5d 5c 7a 2a 72 | 6f 74 5c 72 32 5b 32 5d |l[i]\z*r|ot\r2[2]|
|000049c0| 00 20 20 20 20 20 20 20 | 20 5c 76 6c 6f 63 61 6c |. | \vlocal|
|000049d0| 5b 69 5d 5c 78 3d 74 65 | 6d 70 5f 78 00 20 20 20 |[i]\x=te|mp_x. |
|000049e0| 20 20 20 20 20 5c 76 6c | 6f 63 61 6c 5b 69 5d 5c | \vl|ocal[i]\|
|000049f0| 79 3d 74 65 6d 70 5f 79 | 00 20 20 20 20 20 20 20 |y=temp_y|. |
|00004a00| 20 5c 76 6c 6f 63 61 6c | 5b 69 5d 5c 7a 3d 74 65 | \vlocal|[i]\z=te|
|00004a10| 6d 70 5f 7a 00 20 20 20 | 20 20 20 80 17 20 69 00 |mp_z. | .. i.|
|00004a20| 20 20 20 20 80 0f 20 34 | 00 20 20 20 20 20 20 72 | .. 4|. r|
|00004a30| 6f 74 5c 72 31 5b 31 5d | 3d 20 28 20 43 4f 53 54 |ot\r1[1]|= ( COST|
|00004a40| 41 42 4c 45 28 61 6e 67 | 6c 65 5f 78 29 29 00 20 |ABLE(ang|le_x)). |
|00004a50| 20 20 20 20 20 72 6f 74 | 5c 72 31 5b 32 5d 3d 20 | rot|\r1[2]= |
|00004a60| 28 20 53 49 4e 54 41 42 | 4c 45 28 61 6e 67 6c 65 |( SINTAB|LE(angle|
|00004a70| 5f 78 29 29 00 20 20 20 | 20 20 20 72 6f 74 5c 72 |_x)). | rot\r|
|00004a80| 32 5b 31 5d 3d 20 28 2d | 53 49 4e 54 41 42 4c 45 |2[1]= (-|SINTABLE|
|00004a90| 28 61 6e 67 6c 65 5f 78 | 29 29 00 20 20 20 20 20 |(angle_x|)). |
|00004aa0| 20 72 6f 74 5c 72 32 5b | 32 5d 3d 20 28 20 43 4f | rot\r2[|2]= ( CO|
|00004ab0| 53 54 41 42 4c 45 28 61 | 6e 67 6c 65 5f 78 29 29 |STABLE(a|ngle_x))|
|00004ac0| 00 20 20 20 20 20 20 80 | 16 20 69 3d 30 20 80 18 |. .|. i=0 ..|
|00004ad0| 20 5c 6e 75 6d 76 65 72 | 74 73 00 20 20 20 20 20 | \numver|ts. |
|00004ae0| 20 20 20 74 65 6d 70 5f | 78 3d 5c 76 6c 6f 63 61 | temp_|x=\vloca|
|00004af0| 6c 5b 69 5d 5c 78 00 20 | 20 20 20 20 20 20 20 74 |l[i]\x. | t|
|00004b00| 65 6d 70 5f 79 3d 5c 76 | 6c 6f 63 61 6c 5b 69 5d |emp_y=\v|local[i]|
|00004b10| 5c 79 2a 72 6f 74 5c 72 | 31 5b 31 5d 20 2b 20 5c |\y*rot\r|1[1] + \|
|00004b20| 76 6c 6f 63 61 6c 5b 69 | 5d 5c 7a 2a 72 6f 74 5c |vlocal[i|]\z*rot\|
|00004b30| 72 32 5b 31 5d 00 20 20 | 20 20 20 20 20 20 74 65 |r2[1]. | te|
|00004b40| 6d 70 5f 7a 3d 5c 76 6c | 6f 63 61 6c 5b 69 5d 5c |mp_z=\vl|ocal[i]\|
|00004b50| 79 2a 72 6f 74 5c 72 31 | 5b 32 5d 20 2b 20 5c 76 |y*rot\r1|[2] + \v|
|00004b60| 6c 6f 63 61 6c 5b 69 5d | 5c 7a 2a 72 6f 74 5c 72 |local[i]|\z*rot\r|
|00004b70| 32 5b 32 5d 00 20 20 20 | 20 20 20 20 20 5c 76 6c |2[2]. | \vl|
|00004b80| 6f 63 61 6c 5b 69 5d 5c | 78 3d 74 65 6d 70 5f 78 |ocal[i]\|x=temp_x|
|00004b90| 00 20 20 20 20 20 20 20 | 20 5c 76 6c 6f 63 61 6c |. | \vlocal|
|00004ba0| 5b 69 5d 5c 79 3d 74 65 | 6d 70 5f 79 00 20 20 20 |[i]\y=te|mp_y. |
|00004bb0| 20 20 20 20 20 5c 76 6c | 6f 63 61 6c 5b 69 5d 5c | \vl|ocal[i]\|
|00004bc0| 7a 3d 74 65 6d 70 5f 7a | 00 20 20 20 20 20 20 80 |z=temp_z|. .|
|00004bd0| 17 20 69 00 20 20 20 20 | 80 0f 20 35 00 20 20 20 |. i. |.. 5. |
|00004be0| 20 20 20 72 6f 74 5c 72 | 30 5b 30 5d 3d 20 43 4f | rot\r|0[0]= CO|
|00004bf0| 53 54 41 42 4c 45 28 61 | 6e 67 6c 65 5f 7a 29 00 |STABLE(a|ngle_z).|
|00004c00| 20 20 20 20 20 20 72 6f | 74 5c 72 30 5b 31 5d 3d | ro|t\r0[1]=|
|00004c10| 20 53 49 4e 54 41 42 4c | 45 28 61 6e 67 6c 65 5f | SINTABL|E(angle_|
|00004c20| 7a 29 00 20 20 20 20 20 | 20 72 6f 74 5c 72 31 5b |z). | rot\r1[|
|00004c30| 30 5d 3d 2d 43 4f 53 54 | 41 42 4c 45 28 61 6e 67 |0]=-COST|ABLE(ang|
|00004c40| 6c 65 5f 78 29 2a 53 49 | 4e 54 41 42 4c 45 28 61 |le_x)*SI|NTABLE(a|
|00004c50| 6e 67 6c 65 5f 7a 29 00 | 20 20 20 20 20 20 72 6f |ngle_z).| ro|
|00004c60| 74 5c 72 31 5b 31 5d 3d | 20 43 4f 53 54 41 42 4c |t\r1[1]=| COSTABL|
|00004c70| 45 28 61 6e 67 6c 65 5f | 78 29 2a 43 4f 53 54 41 |E(angle_|x)*COSTA|
|00004c80| 42 4c 45 28 61 6e 67 6c | 65 5f 7a 29 00 20 20 20 |BLE(angl|e_z). |
|00004c90| 20 20 20 72 6f 74 5c 72 | 31 5b 32 5d 3d 20 53 49 | rot\r|1[2]= SI|
|00004ca0| 4e 54 41 42 4c 45 28 61 | 6e 67 6c 65 5f 78 29 00 |NTABLE(a|ngle_x).|
|00004cb0| 20 20 20 20 20 20 72 6f | 74 5c 72 32 5b 30 5d 3d | ro|t\r2[0]=|
|00004cc0| 20 53 49 4e 54 41 42 4c | 45 28 61 6e 67 6c 65 5f | SINTABL|E(angle_|
|00004cd0| 78 29 2a 53 49 4e 54 41 | 42 4c 45 28 61 6e 67 6c |x)*SINTA|BLE(angl|
|00004ce0| 65 5f 7a 29 00 20 20 20 | 20 20 20 72 6f 74 5c 72 |e_z). | rot\r|
|00004cf0| 32 5b 31 5d 3d 2d 53 49 | 4e 54 41 42 4c 45 28 61 |2[1]=-SI|NTABLE(a|
|00004d00| 6e 67 6c 65 5f 78 29 2a | 43 4f 53 54 41 42 4c 45 |ngle_x)*|COSTABLE|
|00004d10| 28 61 6e 67 6c 65 5f 7a | 29 00 20 20 20 20 20 20 |(angle_z|). |
|00004d20| 72 6f 74 5c 72 32 5b 32 | 5d 3d 20 43 4f 53 54 41 |rot\r2[2|]= COSTA|
|00004d30| 42 4c 45 28 61 6e 67 6c | 65 5f 78 29 00 20 20 20 |BLE(angl|e_x). |
|00004d40| 20 20 20 80 16 20 69 3d | 30 20 80 18 20 5c 6e 75 | .. i=|0 .. \nu|
|00004d50| 6d 76 65 72 74 73 00 20 | 20 20 20 20 20 20 20 74 |mverts. | t|
|00004d60| 65 6d 70 5f 78 3d 5c 76 | 6c 6f 63 61 6c 5b 69 5d |emp_x=\v|local[i]|
|00004d70| 5c 78 2a 72 6f 74 5c 72 | 30 5b 30 5d 20 2b 20 5c |\x*rot\r|0[0] + \|
|00004d80| 76 6c 6f 63 61 6c 5b 69 | 5d 5c 79 2a 72 6f 74 5c |vlocal[i|]\y*rot\|
|00004d90| 72 31 5b 30 5d 20 2b 20 | 5c 76 6c 6f 63 61 6c 5b |r1[0] + |\vlocal[|
|00004da0| 69 5d 5c 7a 2a 72 6f 74 | 5c 72 32 5b 30 5d 00 20 |i]\z*rot|\r2[0]. |
|00004db0| 20 20 20 20 20 20 20 74 | 65 6d 70 5f 79 3d 5c 76 | t|emp_y=\v|
|00004dc0| 6c 6f 63 61 6c 5b 69 5d | 5c 78 2a 72 6f 74 5c 72 |local[i]|\x*rot\r|
|00004dd0| 30 5b 31 5d 20 2b 20 5c | 76 6c 6f 63 61 6c 5b 69 |0[1] + \|vlocal[i|
|00004de0| 5d 5c 79 2a 72 6f 74 5c | 72 31 5b 31 5d 20 2b 20 |]\y*rot\|r1[1] + |
|00004df0| 5c 76 6c 6f 63 61 6c 5b | 69 5d 5c 7a 2a 72 6f 74 |\vlocal[|i]\z*rot|
|00004e00| 5c 72 32 5b 31 5d 00 20 | 20 20 20 20 20 20 20 74 |\r2[1]. | t|
|00004e10| 65 6d 70 5f 7a 3d 5c 76 | 6c 6f 63 61 6c 5b 69 5d |emp_z=\v|local[i]|
|00004e20| 5c 79 2a 72 6f 74 5c 72 | 31 5b 32 5d 20 2b 20 5c |\y*rot\r|1[2] + \|
|00004e30| 76 6c 6f 63 61 6c 5b 69 | 5d 5c 7a 2a 72 6f 74 5c |vlocal[i|]\z*rot\|
|00004e40| 72 32 5b 32 5d 00 00 20 | 20 20 20 20 20 20 20 5c |r2[2].. | \|
|00004e50| 76 6c 6f 63 61 6c 5b 69 | 5d 5c 78 3d 74 65 6d 70 |vlocal[i|]\x=temp|
|00004e60| 5f 78 00 20 20 20 20 20 | 20 20 20 5c 76 6c 6f 63 |_x. | \vloc|
|00004e70| 61 6c 5b 69 5d 5c 79 3d | 74 65 6d 70 5f 79 00 20 |al[i]\y=|temp_y. |
|00004e80| 20 20 20 20 20 20 20 5c | 76 6c 6f 63 61 6c 5b 69 | \|vlocal[i|
|00004e90| 5d 5c 7a 3d 74 65 6d 70 | 5f 7a 00 20 20 20 20 20 |]\z=temp|_z. |
|00004ea0| 20 80 17 20 69 00 20 20 | 20 20 80 0f 20 36 00 20 | .. i. | .. 6. |
|00004eb0| 20 20 20 20 20 72 6f 74 | 5c 72 30 5b 30 5d 3d 20 | rot|\r0[0]= |
|00004ec0| 43 4f 53 54 41 42 4c 45 | 28 61 6e 67 6c 65 5f 79 |COSTABLE|(angle_y|
|00004ed0| 29 00 20 20 20 20 20 20 | 72 6f 74 5c 72 30 5b 32 |). |rot\r0[2|
|00004ee0| 5d 3d 2d 53 49 4e 54 41 | 42 4c 45 28 61 6e 67 6c |]=-SINTA|BLE(angl|
|00004ef0| 65 5f 79 29 00 00 20 20 | 20 20 20 20 72 6f 74 5c |e_y).. | rot\|
|00004f00| 72 31 5b 30 5d 3d 20 53 | 49 4e 54 41 42 4c 45 28 |r1[0]= S|INTABLE(|
|00004f10| 61 6e 67 6c 65 5f 78 29 | 2a 53 49 4e 54 41 42 4c |angle_x)|*SINTABL|
|00004f20| 45 28 61 6e 67 6c 65 5f | 79 29 00 20 20 20 20 20 |E(angle_|y). |
|00004f30| 20 72 6f 74 5c 72 31 5b | 31 5d 3d 20 43 4f 53 54 | rot\r1[|1]= COST|
|00004f40| 41 42 4c 45 28 61 6e 67 | 6c 65 5f 78 29 00 20 20 |ABLE(ang|le_x). |
|00004f50| 20 20 20 20 72 6f 74 5c | 72 31 5b 32 5d 3d 20 53 | rot\|r1[2]= S|
|00004f60| 49 4e 54 41 42 4c 45 28 | 61 6e 67 6c 65 5f 78 29 |INTABLE(|angle_x)|
|00004f70| 2a 43 4f 53 54 41 42 4c | 45 28 61 6e 67 6c 65 5f |*COSTABL|E(angle_|
|00004f80| 79 29 00 00 20 20 20 20 | 20 20 72 6f 74 5c 72 32 |y).. | rot\r2|
|00004f90| 5b 30 5d 3d 20 43 4f 53 | 54 41 42 4c 45 28 61 6e |[0]= COS|TABLE(an|
|00004fa0| 67 6c 65 5f 78 29 2a 53 | 49 4e 54 41 42 4c 45 28 |gle_x)*S|INTABLE(|
|00004fb0| 61 6e 67 6c 65 5f 79 29 | 00 20 20 20 20 20 20 72 |angle_y)|. r|
|00004fc0| 6f 74 5c 72 32 5b 31 5d | 3d 2d 53 49 4e 54 41 42 |ot\r2[1]|=-SINTAB|
|00004fd0| 4c 45 28 61 6e 67 6c 65 | 5f 78 29 00 20 20 20 20 |LE(angle|_x). |
|00004fe0| 20 20 72 6f 74 5c 72 32 | 5b 32 5d 3d 20 43 4f 53 | rot\r2|[2]= COS|
|00004ff0| 54 41 42 4c 45 28 61 6e | 67 6c 65 5f 78 29 2a 43 |TABLE(an|gle_x)*C|
|00005000| 4f 53 54 41 42 4c 45 28 | 61 6e 67 6c 65 5f 79 29 |OSTABLE(|angle_y)|
|00005010| 00 00 20 20 20 20 20 20 | 80 16 20 69 3d 30 20 80 |.. |.. i=0 .|
|00005020| 18 20 5c 6e 75 6d 76 65 | 72 74 73 00 20 20 20 20 |. \numve|rts. |
|00005030| 20 20 20 20 74 65 6d 70 | 5f 78 3d 5c 76 6c 6f 63 | temp|_x=\vloc|
|00005040| 61 6c 5b 69 5d 5c 78 2a | 72 6f 74 5c 72 30 5b 30 |al[i]\x*|rot\r0[0|
|00005050| 5d 20 2b 20 5c 76 6c 6f | 63 61 6c 5b 69 5d 5c 79 |] + \vlo|cal[i]\y|
|00005060| 2a 72 6f 74 5c 72 31 5b | 30 5d 20 2b 20 5c 76 6c |*rot\r1[|0] + \vl|
|00005070| 6f 63 61 6c 5b 69 5d 5c | 7a 2a 72 6f 74 5c 72 32 |ocal[i]\|z*rot\r2|
|00005080| 5b 30 5d 00 20 20 20 20 | 20 20 20 20 74 65 6d 70 |[0]. | temp|
|00005090| 5f 79 3d 5c 76 6c 6f 63 | 61 6c 5b 69 5d 5c 79 2a |_y=\vloc|al[i]\y*|
|000050a0| 72 6f 74 5c 72 31 5b 31 | 5d 20 2b 20 5c 76 6c 6f |rot\r1[1|] + \vlo|
|000050b0| 63 61 6c 5b 69 5d 5c 7a | 2a 72 6f 74 5c 72 32 5b |cal[i]\z|*rot\r2[|
|000050c0| 31 5d 00 20 20 20 20 20 | 20 20 20 74 65 6d 70 5f |1]. | temp_|
|000050d0| 7a 3d 5c 76 6c 6f 63 61 | 6c 5b 69 5d 5c 78 2a 72 |z=\vloca|l[i]\x*r|
|000050e0| 6f 74 5c 72 30 5b 32 5d | 20 2b 20 5c 76 6c 6f 63 |ot\r0[2]| + \vloc|
|000050f0| 61 6c 5b 69 5d 5c 79 2a | 72 6f 74 5c 72 31 5b 32 |al[i]\y*|rot\r1[2|
|00005100| 5d 20 2b 20 5c 76 6c 6f | 63 61 6c 5b 69 5d 5c 7a |] + \vlo|cal[i]\z|
|00005110| 2a 72 6f 74 5c 72 32 5b | 32 5d 00 20 20 20 20 20 |*rot\r2[|2]. |
|00005120| 20 20 20 5c 76 6c 6f 63 | 61 6c 5b 69 5d 5c 78 3d | \vloc|al[i]\x=|
|00005130| 74 65 6d 70 5f 78 00 20 | 20 20 20 20 20 20 20 5c |temp_x. | \|
|00005140| 76 6c 6f 63 61 6c 5b 69 | 5d 5c 79 3d 74 65 6d 70 |vlocal[i|]\y=temp|
|00005150| 5f 79 00 20 20 20 20 20 | 20 20 20 5c 76 6c 6f 63 |_y. | \vloc|
|00005160| 61 6c 5b 69 5d 5c 7a 3d | 74 65 6d 70 5f 7a 00 20 |al[i]\z=|temp_z. |
|00005170| 20 20 20 20 20 80 17 20 | 69 00 20 20 20 20 80 0f | .. |i. ..|
|00005180| 20 37 00 20 20 20 20 20 | 20 4d 61 74 49 64 65 6e | 7. | MatIden|
|00005190| 74 69 74 79 34 78 34 7b | 72 6f 74 61 74 65 5f 78 |tity4x4{|rotate_x|
|000051a0| 7d 00 20 20 20 20 20 20 | 72 6f 74 61 74 65 5f 78 |}. |rotate_x|
|000051b0| 5c 72 31 5b 31 5d 3d 20 | 28 20 43 4f 53 54 41 42 |\r1[1]= |( COSTAB|
|000051c0| 4c 45 28 61 6e 67 6c 65 | 5f 78 29 29 00 20 20 20 |LE(angle|_x)). |
|000051d0| 20 20 20 72 6f 74 61 74 | 65 5f 78 5c 72 31 5b 32 | rotat|e_x\r1[2|
|000051e0| 5d 3d 20 28 20 53 49 4e | 54 41 42 4c 45 28 61 6e |]= ( SIN|TABLE(an|
|000051f0| 67 6c 65 5f 78 29 29 00 | 20 20 20 20 20 20 72 6f |gle_x)).| ro|
|00005200| 74 61 74 65 5f 78 5c 72 | 32 5b 31 5d 3d 20 28 2d |tate_x\r|2[1]= (-|
|00005210| 53 49 4e 54 41 42 4c 45 | 28 61 6e 67 6c 65 5f 78 |SINTABLE|(angle_x|
|00005220| 29 29 00 20 20 20 20 20 | 20 72 6f 74 61 74 65 5f |)). | rotate_|
|00005230| 78 5c 72 32 5b 32 5d 3d | 20 28 20 43 4f 53 54 41 |x\r2[2]=| ( COSTA|
|00005240| 42 4c 45 28 61 6e 67 6c | 65 5f 78 29 29 00 20 20 |BLE(angl|e_x)). |
|00005250| 20 20 20 20 4d 61 74 49 | 64 65 6e 74 69 74 79 34 | MatI|dentity4|
|00005260| 78 34 7b 72 6f 74 61 74 | 65 5f 79 7d 00 20 20 20 |x4{rotat|e_y}. |
|00005270| 20 20 20 72 6f 74 61 74 | 65 5f 79 5c 72 30 5b 30 | rotat|e_y\r0[0|
|00005280| 5d 3d 20 28 20 43 4f 53 | 54 41 42 4c 45 28 61 6e |]= ( COS|TABLE(an|
|00005290| 67 6c 65 5f 79 29 29 00 | 20 20 20 20 20 20 72 6f |gle_y)).| ro|
|000052a0| 74 61 74 65 5f 79 5c 72 | 30 5b 32 5d 3d 20 28 2d |tate_y\r|0[2]= (-|
|000052b0| 53 49 4e 54 41 42 4c 45 | 28 61 6e 67 6c 65 5f 79 |SINTABLE|(angle_y|
|000052c0| 29 29 00 20 20 20 20 20 | 20 72 6f 74 61 74 65 5f |)). | rotate_|
|000052d0| 79 5c 72 32 5b 30 5d 3d | 20 28 20 53 49 4e 54 41 |y\r2[0]=| ( SINTA|
|000052e0| 42 4c 45 28 61 6e 67 6c | 65 5f 79 29 29 00 20 20 |BLE(angl|e_y)). |
|000052f0| 20 20 20 20 72 6f 74 61 | 74 65 5f 79 5c 72 32 5b | rota|te_y\r2[|
|00005300| 32 5d 3d 20 28 20 43 4f | 53 54 41 42 4c 45 28 61 |2]= ( CO|STABLE(a|
|00005310| 6e 67 6c 65 5f 79 29 29 | 00 20 20 20 20 20 20 4d |ngle_y))|. M|
|00005320| 61 74 49 64 65 6e 74 69 | 74 79 34 78 34 7b 72 6f |atIdenti|ty4x4{ro|
|00005330| 74 61 74 65 5f 7a 7d 00 | 20 20 20 20 20 20 72 6f |tate_z}.| ro|
|00005340| 74 61 74 65 5f 7a 5c 72 | 30 5b 30 5d 3d 20 28 20 |tate_z\r|0[0]= ( |
|00005350| 43 4f 53 54 41 42 4c 45 | 28 61 6e 67 6c 65 5f 7a |COSTABLE|(angle_z|
|00005360| 29 29 00 20 20 20 20 20 | 20 72 6f 74 61 74 65 5f |)). | rotate_|
|00005370| 7a 5c 72 30 5b 31 5d 3d | 20 28 20 53 49 4e 54 41 |z\r0[1]=| ( SINTA|
|00005380| 42 4c 45 28 61 6e 67 6c | 65 5f 7a 29 29 00 20 20 |BLE(angl|e_z)). |
|00005390| 20 20 20 20 72 6f 74 61 | 74 65 5f 7a 5c 72 31 5b | rota|te_z\r1[|
|000053a0| 30 5d 3d 20 28 2d 53 49 | 4e 54 41 42 4c 45 28 61 |0]= (-SI|NTABLE(a|
|000053b0| 6e 67 6c 65 5f 7a 29 29 | 00 20 20 20 20 20 20 72 |ngle_z))|. r|
|000053c0| 6f 74 61 74 65 5f 7a 5c | 72 31 5b 31 5d 3d 20 28 |otate_z\|r1[1]= (|
|000053d0| 20 43 4f 53 54 41 42 4c | 45 28 61 6e 67 6c 65 5f | COSTABL|E(angle_|
|000053e0| 7a 29 29 00 20 20 20 20 | 20 20 4d 61 74 4d 75 6c |z)). | MatMul|
|000053f0| 74 34 78 34 53 7b 72 6f | 74 61 74 65 5f 78 2c 20 |t4x4S{ro|tate_x, |
|00005400| 72 6f 74 61 74 65 5f 79 | 2c 20 74 65 6d 70 7d 00 |rotate_y|, temp}.|
|00005410| 20 20 20 20 20 20 4d 61 | 74 4d 75 6c 74 34 78 34 | Ma|tMult4x4|
|00005420| 53 7b 74 65 6d 70 2c 20 | 72 6f 74 61 74 65 5f 7a |S{temp, |rotate_z|
|00005430| 2c 20 72 6f 74 7d 00 20 | 20 20 20 20 20 80 16 20 |, rot}. | .. |
|00005440| 69 3d 30 20 80 18 20 5c | 6e 75 6d 76 65 72 74 73 |i=0 .. \|numverts|
|00005450| 00 20 20 20 20 20 20 20 | 20 74 65 6d 70 5f 78 3d |. | temp_x=|
|00005460| 5c 76 6c 6f 63 61 6c 5b | 69 5d 5c 78 2a 72 6f 74 |\vlocal[|i]\x*rot|
|00005470| 5c 72 30 5b 30 5d 20 2b | 20 5c 76 6c 6f 63 61 6c |\r0[0] +| \vlocal|
|00005480| 5b 69 5d 5c 79 2a 72 6f | 74 5c 72 31 5b 30 5d 20 |[i]\y*ro|t\r1[0] |
|00005490| 2b 20 5c 76 6c 6f 63 61 | 6c 5b 69 5d 5c 7a 2a 72 |+ \vloca|l[i]\z*r|
|000054a0| 6f 74 5c 72 32 5b 30 5d | 00 20 20 20 20 20 20 20 |ot\r2[0]|. |
|000054b0| 20 74 65 6d 70 5f 79 3d | 5c 76 6c 6f 63 61 6c 5b | temp_y=|\vlocal[|
|000054c0| 69 5d 5c 78 2a 72 6f 74 | 5c 72 30 5b 31 5d 20 2b |i]\x*rot|\r0[1] +|
|000054d0| 20 5c 76 6c 6f 63 61 6c | 5b 69 5d 5c 79 2a 72 6f | \vlocal|[i]\y*ro|
|000054e0| 74 5c 72 31 5b 31 5d 20 | 2b 20 5c 76 6c 6f 63 61 |t\r1[1] |+ \vloca|
|000054f0| 6c 5b 69 5d 5c 7a 2a 72 | 6f 74 5c 72 32 5b 31 5d |l[i]\z*r|ot\r2[1]|
|00005500| 00 20 20 20 20 20 20 20 | 20 74 65 6d 70 5f 7a 3d |. | temp_z=|
|00005510| 5c 76 6c 6f 63 61 6c 5b | 69 5d 5c 78 2a 72 6f 74 |\vlocal[|i]\x*rot|
|00005520| 5c 72 30 5b 32 5d 20 2b | 20 5c 76 6c 6f 63 61 6c |\r0[2] +| \vlocal|
|00005530| 5b 69 5d 5c 79 2a 72 6f | 74 5c 72 31 5b 32 5d 20 |[i]\y*ro|t\r1[2] |
|00005540| 2b 20 5c 76 6c 6f 63 61 | 6c 5b 69 5d 5c 7a 2a 72 |+ \vloca|l[i]\z*r|
|00005550| 6f 74 5c 72 32 5b 32 5d | 00 20 20 20 20 20 20 20 |ot\r2[2]|. |
|00005560| 20 5c 76 6c 6f 63 61 6c | 5b 69 5d 5c 78 3d 74 65 | \vlocal|[i]\x=te|
|00005570| 6d 70 5f 78 00 20 20 20 | 20 20 20 20 20 5c 76 6c |mp_x. | \vl|
|00005580| 6f 63 61 6c 5b 69 5d 5c | 79 3d 74 65 6d 70 5f 79 |ocal[i]\|y=temp_y|
|00005590| 00 20 20 20 20 20 20 20 | 20 5c 76 6c 6f 63 61 6c |. | \vlocal|
|000055a0| 5b 69 5d 5c 7a 3d 74 65 | 6d 70 5f 7a 00 20 20 20 |[i]\z=te|mp_z. |
|000055b0| 20 20 20 80 17 20 69 00 | 20 20 80 02 20 80 0e 00 | .. i.| .. ...|
|000055c0| 20 20 3b 00 20 20 3b 20 | 6d 75 6c 74 69 70 6c 79 | ;. ; |multiply|
|000055d0| 20 65 61 63 68 20 70 6f | 69 6e 74 20 69 6e 20 61 | each po|int in a|
|000055e0| 6e 20 6f 62 6a 65 63 74 | 20 62 79 20 74 72 61 6e |n object| by tran|
|000055f0| 73 66 6f 72 6d 61 74 69 | 6f 6e 20 6d 61 74 72 69 |sformati|on matri|
|00005600| 78 00 20 20 3b 20 73 68 | 6f 75 6c 64 20 6e 6f 74 |x. ; sh|ould not|
|00005610| 20 62 65 20 6e 65 63 65 | 73 73 61 72 79 20 74 6f | be nece|ssary to|
|00005620| 20 6d 75 6c 74 69 70 6c | 79 20 65 61 63 68 20 70 | multipl|y each p|
|00005630| 6f 69 6e 74 2c 20 6a 75 | 73 74 20 6f 6e 65 00 20 |oint, ju|st one. |
|00005640| 20 3b 20 61 6e 64 20 61 | 70 70 6c 79 20 28 64 78 | ; and a|pply (dx|
|00005650| 2c 64 79 2c 64 7a 29 20 | 74 6f 20 61 6c 6c 20 74 |,dy,dz) |to all t|
|00005660| 68 65 20 72 65 73 74 21 | 21 21 00 20 20 3b 00 80 |he rest!|!!. ;..|
|00005670| 02 20 80 08 00 00 3b 2d | 2d 2d 2d 2d 2d 2d 2d 2d |. ....;-|--------|
|00005680| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00005690| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000056a0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000056b0| 2d 2d 2d 2d 2d 00 3b 2d | 2d 2d 2d 2d 2d 2d 2d 2d |-----.;-|--------|
|000056c0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000056d0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000056e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000056f0| 2d 2d 2d 2d 2d 00 80 08 | 20 44 72 61 77 54 6f 70 |-----...| DrawTop|
|00005700| 54 72 69 61 6e 67 6c 65 | 7b 2a 72 31 2e 70 69 78 |Triangle|{*r1.pix|
|00005710| 65 6c 2c 20 2a 72 32 2e | 70 69 78 65 6c 2c 20 2a |el, *r2.|pixel, *|
|00005720| 72 33 2e 70 69 78 65 6c | 2c 20 63 6f 6c 2e 77 7d |r3.pixel|, col.w}|
|00005730| 00 3b 20 44 72 61 77 73 | 20 61 20 74 72 69 61 6e |.; Draws| a trian|
|00005740| 67 6c 65 20 74 68 61 74 | 20 68 61 73 20 61 20 66 |gle that| has a f|
|00005750| 6c 61 74 20 74 6f 70 00 | 3b 00 20 20 80 33 2e 66 |lat top.|;. .3.f|
|00005760| 20 64 78 5f 72 69 67 68 | 74 2c 20 64 78 5f 6c 65 | dx_righ|t, dx_le|
|00005770| 66 74 2c 20 78 73 2c 20 | 78 65 2c 20 68 65 69 67 |ft, xs, |xe, heig|
|00005780| 68 74 00 20 20 80 33 2e | 6c 20 74 65 6d 70 5f 79 |ht. .3.|l temp_y|
|00005790| 2c 20 72 69 67 68 74 2c | 20 6c 65 66 74 2c 20 78 |, right,| left, x|
|000057a0| 31 2c 20 79 31 2c 20 78 | 32 2c 20 79 32 2c 20 78 |1, y1, x|2, y2, x|
|000057b0| 33 2c 20 79 33 00 20 20 | 80 15 20 4d 49 4e 59 2c |3, y3. |.. MINY,|
|000057c0| 20 4d 41 58 59 2c 20 4d | 49 4e 58 2c 20 20 4d 41 | MAXY, M|INX, MA|
|000057d0| 58 58 00 00 20 20 78 31 | 3d 2a 72 31 5c 78 20 3a |XX.. x1|=*r1\x :|
|000057e0| 20 79 31 3d 2a 72 31 5c | 79 20 3a 20 78 32 3d 2a | y1=*r1\|y : x2=*|
|000057f0| 72 32 5c 78 20 3a 20 79 | 32 3d 2a 72 32 5c 79 20 |r2\x : y|2=*r2\y |
|00005800| 3a 20 78 33 3d 2a 72 33 | 5c 78 20 3a 20 79 33 3d |: x3=*r3|\x : y3=|
|00005810| 2a 72 33 5c 79 00 00 20 | 20 3b 74 65 73 74 20 6f |*r3\y.. | ;test o|
|00005820| 72 64 65 72 20 6f 66 20 | 78 31 20 61 6e 64 20 78 |rder of |x1 and x|
|00005830| 32 00 20 20 80 0b 20 78 | 32 3c 78 31 20 80 21 20 |2. .. x|2<x1 .! |
|00005840| 80 c9 20 78 31 2c 78 32 | 00 00 20 20 68 65 69 67 |.. x1,x2|.. heig|
|00005850| 68 74 20 20 20 3d 20 20 | 79 33 2d 79 31 00 00 20 |ht = |y3-y1.. |
|00005860| 20 64 78 5f 6c 65 66 74 | 20 20 3d 20 28 78 33 2d | dx_left| = (x3-|
|00005870| 78 31 29 2f 68 65 69 67 | 68 74 00 20 20 64 78 5f |x1)/heig|ht. dx_|
|00005880| 72 69 67 68 74 20 3d 20 | 28 78 33 2d 78 32 29 2f |right = |(x3-x2)/|
|00005890| 68 65 69 67 68 74 00 00 | 20 20 3b 73 65 74 20 73 |height..| ;set s|
|000058a0| 74 61 72 74 69 6e 67 20 | 70 6f 69 6e 74 00 20 20 |tarting |point. |
|000058b0| 78 73 3d 78 31 00 20 20 | 78 65 3d 78 32 2b 30 2e |xs=x1. |xe=x2+0.|
|000058c0| 35 00 00 20 20 3b 70 65 | 72 66 6f 72 6d 20 79 20 |5.. ;pe|rform y |
|000058d0| 63 6c 69 70 70 69 6e 67 | 00 20 20 80 0b 20 79 31 |clipping|. .. y1|
|000058e0| 3c 4d 49 4e 59 00 20 20 | 20 20 78 73 3d 78 73 2b |<MINY. | xs=xs+|
|000058f0| 64 78 5f 6c 65 66 74 2a | 28 2d 79 31 2b 4d 49 4e |dx_left*|(-y1+MIN|
|00005900| 59 29 00 20 20 20 20 78 | 65 3d 78 65 2b 64 78 5f |Y). x|e=xe+dx_|
|00005910| 72 69 67 68 74 2a 28 2d | 79 31 2b 4d 49 4e 59 29 |right*(-|y1+MINY)|
|00005920| 00 20 20 20 20 79 31 3d | 4d 49 4e 59 00 20 20 80 |. y1=|MINY. .|
|00005930| c0 00 00 20 20 80 0b 20 | 79 33 3e 4d 41 58 59 20 |... .. |y3>MAXY |
|00005940| 80 21 20 79 33 3d 4d 41 | 58 59 00 00 20 20 80 0b |.! y3=MA|XY.. ..|
|00005950| 20 28 78 31 3e 3d 4d 49 | 4e 58 20 80 42 20 78 31 | (x1>=MI|NX .B x1|
|00005960| 3c 3d 4d 41 58 58 20 80 | 42 20 78 32 3e 3d 4d 49 |<=MAXX .|B x2>=MI|
|00005970| 4e 58 20 80 42 20 78 32 | 3c 3d 4d 41 58 58 20 80 |NX .B x2|<=MAXX .|
|00005980| 42 20 78 33 3e 3d 4d 49 | 4e 58 20 80 42 20 78 33 |B x3>=MI|NX .B x3|
|00005990| 3c 3d 4d 41 58 58 29 00 | 20 20 3b 64 72 61 77 20 |<=MAXX).| ;draw |
|000059a0| 74 68 65 20 74 72 69 61 | 6e 67 6c 65 00 20 20 20 |the tria|ngle. |
|000059b0| 20 80 16 20 74 65 6d 70 | 5f 79 3d 79 31 20 80 18 | .. temp|_y=y1 ..|
|000059c0| 20 79 33 00 20 20 20 20 | 20 20 bb 85 20 78 73 2c | y3. | .. xs,|
|000059d0| 20 74 65 6d 70 5f 79 2c | 20 78 65 2c 20 74 65 6d | temp_y,| xe, tem|
|000059e0| 70 5f 79 2c 20 63 6f 6c | 00 20 20 20 20 20 20 78 |p_y, col|. x|
|000059f0| 73 2b 64 78 5f 6c 65 66 | 74 00 20 20 20 20 20 20 |s+dx_lef|t. |
|00005a00| 78 65 2b 64 78 5f 72 69 | 67 68 74 00 20 20 20 20 |xe+dx_ri|ght. |
|00005a10| 80 17 20 74 65 6d 70 5f | 79 00 20 20 80 22 00 20 |.. temp_|y. .". |
|00005a20| 20 3b 63 6c 69 70 70 69 | 6e 67 20 6e 65 65 64 65 | ;clippi|ng neede|
|00005a30| 64 00 20 20 20 20 80 16 | 20 74 65 6d 70 5f 79 3d |d. ..| temp_y=|
|00005a40| 79 31 20 80 18 20 79 33 | 00 20 20 20 20 20 20 6c |y1 .. y3|. l|
|00005a50| 65 66 74 3d 78 73 00 20 | 20 20 20 20 20 72 69 67 |eft=xs. | rig|
|00005a60| 68 74 3d 78 65 00 20 20 | 20 20 20 20 78 73 2b 64 |ht=xe. | xs+d|
|00005a70| 78 5f 6c 65 66 74 00 20 | 20 20 20 20 20 78 65 2b |x_left. | xe+|
|00005a80| 64 78 5f 72 69 67 68 74 | 00 20 20 20 20 20 20 80 |dx_right|. .|
|00005a90| 0b 20 6c 65 66 74 3c 4d | 49 4e 58 00 20 20 20 20 |. left<M|INX. |
|00005aa0| 20 20 20 20 6c 65 66 74 | 3d 4d 49 4e 58 00 20 20 | left|=MINX. |
|00005ab0| 20 20 20 20 20 20 80 0b | 20 72 69 67 68 74 3c 4d | ..| right<M|
|00005ac0| 49 4e 58 00 20 20 20 20 | 20 20 20 20 20 20 80 be |INX. | ..|
|00005ad0| 20 80 0b 3a 20 80 05 20 | 63 6f 6e 74 69 6e 75 65 | ..: .. |continue|
|00005ae0| 31 00 20 20 20 20 20 20 | 20 20 80 c0 00 20 20 20 |1. | ... |
|00005af0| 20 20 20 80 c0 00 20 20 | 20 20 20 20 80 0b 20 72 | ... | .. r|
|00005b00| 69 67 68 74 3e 4d 41 58 | 58 00 20 20 20 20 20 20 |ight>MAX|X. |
|00005b10| 20 20 72 69 67 68 74 3d | 4d 41 58 58 00 20 20 20 | right=|MAXX. |
|00005b20| 20 20 20 20 20 80 0b 20 | 6c 65 66 74 3e 4d 41 58 | .. |left>MAX|
|00005b30| 58 00 20 20 20 20 20 20 | 20 20 20 20 80 be 20 80 |X. | .. .|
|00005b40| 0b 3a 20 80 05 20 63 6f | 6e 74 69 6e 75 65 31 00 |.: .. co|ntinue1.|
|00005b50| 20 20 20 20 20 20 20 20 | 80 c0 00 20 20 20 20 20 | |... |
|00005b60| 20 80 c0 00 20 20 20 20 | 20 20 bb 85 20 6c 65 66 | ... | .. lef|
|00005b70| 74 2c 20 74 65 6d 70 5f | 79 2c 20 72 69 67 68 74 |t, temp_|y, right|
|00005b80| 2c 20 74 65 6d 70 5f 79 | 2c 20 63 6f 6c 00 20 20 |, temp_y|, col. |
|00005b90| 20 20 63 6f 6e 74 69 6e | 75 65 31 3a 00 20 20 20 | contin|ue1:. |
|00005ba0| 20 80 17 20 74 65 6d 70 | 5f 79 00 20 20 80 c0 00 | .. temp|_y. ...|
|00005bb0| 80 02 20 80 08 00 00 3b | 2d 2d 2d 2d 2d 2d 2d 2d |.. ....;|--------|
|00005bc0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00005bd0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00005be0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00005bf0| 2d 2d 2d 2d 2d 2d 00 80 | 08 20 44 72 61 77 42 6f |------..|. DrawBo|
|00005c00| 74 74 6f 6d 54 72 69 61 | 6e 67 6c 65 7b 2a 73 31 |ttomTria|ngle{*s1|
|00005c10| 2e 70 69 78 65 6c 2c 20 | 2a 73 32 2e 70 69 78 65 |.pixel, |*s2.pixe|
|00005c20| 6c 2c 20 2a 73 33 2e 70 | 69 78 65 6c 2c 20 63 2e |l, *s3.p|ixel, c.|
|00005c30| 77 7d 00 3b 20 44 72 61 | 77 73 20 61 20 74 72 69 |w}.; Dra|ws a tri|
|00005c40| 61 6e 67 6c 65 20 77 69 | 74 68 20 66 6c 61 74 20 |angle wi|th flat |
|00005c50| 62 6f 74 74 6f 6d 00 3b | 00 20 20 80 33 2e 66 20 |bottom.;|. .3.f |
|00005c60| 64 78 5f 6c 65 66 74 2c | 20 64 78 5f 72 69 67 68 |dx_left,| dx_righ|
|00005c70| 74 2c 20 78 73 2c 20 78 | 65 2c 20 68 65 69 67 68 |t, xs, x|e, heigh|
|00005c80| 74 00 20 20 80 33 2e 6c | 20 74 65 6d 70 5f 78 2c |t. .3.l| temp_x,|
|00005c90| 20 74 65 6d 70 5f 79 2c | 20 72 69 67 68 74 2c 20 | temp_y,| right, |
|00005ca0| 6c 65 66 74 2c 20 78 31 | 2c 20 79 31 2c 20 78 32 |left, x1|, y1, x2|
|00005cb0| 2c 20 79 32 2c 20 78 33 | 2c 20 79 33 00 20 20 80 |, y2, x3|, y3. .|
|00005cc0| 15 20 4d 49 4e 59 2c 20 | 4d 41 58 59 2c 20 4d 49 |. MINY, |MAXY, MI|
|00005cd0| 4e 58 2c 20 4d 41 58 58 | 00 00 20 20 78 31 3d 2a |NX, MAXX|.. x1=*|
|00005ce0| 73 31 5c 78 3a 79 31 3d | 2a 73 31 5c 79 3a 78 32 |s1\x:y1=|*s1\y:x2|
|00005cf0| 3d 2a 73 32 5c 78 3a 79 | 32 3d 2a 73 32 5c 79 3a |=*s2\x:y|2=*s2\y:|
|00005d00| 78 33 3d 2a 73 33 5c 78 | 3a 79 33 3d 2a 73 33 5c |x3=*s3\x|:y3=*s3\|
|00005d10| 79 00 00 20 20 80 0b 20 | 78 33 3c 78 32 20 80 21 |y.. .. |x3<x2 .!|
|00005d20| 20 80 c9 20 78 33 2c 78 | 32 00 00 20 20 68 65 69 | .. x3,x|2.. hei|
|00005d30| 67 68 74 20 20 3d 20 79 | 33 2d 79 31 00 20 20 64 |ght = y|3-y1. d|
|00005d40| 78 5f 6c 65 66 74 20 3d | 20 28 78 32 2d 78 31 29 |x_left =| (x2-x1)|
|00005d50| 2f 68 65 69 67 68 74 00 | 20 20 64 78 5f 72 69 67 |/height.| dx_rig|
|00005d60| 68 74 3d 20 28 78 33 2d | 78 31 29 2f 68 65 69 67 |ht= (x3-|x1)/heig|
|00005d70| 68 74 00 00 20 20 78 73 | 3d 78 31 00 20 20 78 65 |ht.. xs|=x1. xe|
|00005d80| 3d 78 31 2b 30 2e 35 00 | 00 20 20 80 0b 20 79 31 |=x1+0.5.|. .. y1|
|00005d90| 3c 4d 49 4e 59 00 20 20 | 20 20 78 73 3d 78 73 2b |<MINY. | xs=xs+|
|00005da0| 64 78 5f 6c 65 66 74 2a | 28 2d 79 31 2b 4d 49 4e |dx_left*|(-y1+MIN|
|00005db0| 59 29 00 20 20 20 20 78 | 65 3d 78 65 2b 64 78 5f |Y). x|e=xe+dx_|
|00005dc0| 72 69 67 68 74 2a 28 2d | 79 31 2b 4d 49 4e 59 29 |right*(-|y1+MINY)|
|00005dd0| 00 20 20 20 20 79 31 3d | 4d 49 4e 59 00 20 20 80 |. y1=|MINY. .|
|00005de0| c0 00 00 20 20 80 0b 20 | 79 33 3e 4d 41 58 59 20 |... .. |y3>MAXY |
|00005df0| 80 21 20 79 33 3d 4d 41 | 58 59 00 00 20 20 20 80 |.! y3=MA|XY.. .|
|00005e00| 0b 20 28 78 31 3e 3d 4d | 49 4e 58 20 80 42 20 78 |. (x1>=M|INX .B x|
|00005e10| 31 3c 3d 4d 41 58 58 20 | 80 42 20 78 32 3e 3d 4d |1<=MAXX |.B x2>=M|
|00005e20| 49 4e 58 20 80 42 20 78 | 32 3c 3d 4d 41 58 58 20 |INX .B x|2<=MAXX |
|00005e30| 80 42 20 78 33 3e 3d 4d | 49 4e 58 20 80 42 20 78 |.B x3>=M|INX .B x|
|00005e40| 33 3c 3d 4d 41 58 58 29 | 00 20 20 20 3b 64 72 61 |3<=MAXX)|. ;dra|
|00005e50| 77 20 74 72 69 61 6e 67 | 6c 65 00 20 20 20 20 20 |w triang|le. |
|00005e60| 80 16 20 74 65 6d 70 5f | 79 3d 79 31 20 80 18 20 |.. temp_|y=y1 .. |
|00005e70| 79 33 00 20 20 20 20 20 | 20 bb 85 20 78 73 2c 20 |y3. | .. xs, |
|00005e80| 74 65 6d 70 5f 79 2c 20 | 78 65 2c 20 74 65 6d 70 |temp_y, |xe, temp|
|00005e90| 5f 79 2c 20 63 00 20 20 | 20 20 20 20 78 73 2b 64 |_y, c. | xs+d|
|00005ea0| 78 5f 6c 65 66 74 00 20 | 20 20 20 20 20 78 65 2b |x_left. | xe+|
|00005eb0| 64 78 5f 72 69 67 68 74 | 00 20 20 20 20 20 80 17 |dx_right|. ..|
|00005ec0| 20 74 65 6d 70 5f 79 00 | 20 20 20 80 22 00 20 20 | temp_y.| .". |
|00005ed0| 20 3b 63 6c 69 70 70 69 | 6e 67 20 6e 65 65 64 65 | ;clippi|ng neede|
|00005ee0| 64 00 20 20 20 20 80 16 | 20 74 65 6d 70 5f 79 3d |d. ..| temp_y=|
|00005ef0| 79 31 20 80 18 20 79 33 | 00 20 20 20 20 20 20 6c |y1 .. y3|. l|
|00005f00| 65 66 74 3d 78 73 00 20 | 20 20 20 20 20 72 69 67 |eft=xs. | rig|
|00005f10| 68 74 3d 78 65 00 20 20 | 20 20 20 20 78 73 2b 64 |ht=xe. | xs+d|
|00005f20| 78 5f 6c 65 66 74 00 20 | 20 20 20 20 20 78 65 2b |x_left. | xe+|
|00005f30| 64 78 5f 72 69 67 68 74 | 00 20 20 20 20 20 20 80 |dx_right|. .|
|00005f40| 0b 20 6c 65 66 74 3c 4d | 49 4e 58 00 20 20 20 20 |. left<M|INX. |
|00005f50| 20 20 20 20 6c 65 66 74 | 3d 4d 49 4e 58 00 20 20 | left|=MINX. |
|00005f60| 20 20 20 20 20 20 80 0b | 20 72 69 67 68 74 3c 4d | ..| right<M|
|00005f70| 49 4e 58 00 20 20 20 20 | 20 20 20 20 20 20 80 be |INX. | ..|
|00005f80| 20 80 0b 3a 20 80 05 20 | 63 6f 6e 74 69 6e 75 65 | ..: .. |continue|
|00005f90| 33 00 20 20 20 20 20 20 | 20 20 80 c0 00 20 20 20 |3. | ... |
|00005fa0| 20 20 20 80 c0 00 20 20 | 20 20 20 20 80 0b 20 72 | ... | .. r|
|00005fb0| 69 67 68 74 3e 4d 41 58 | 58 00 20 20 20 20 20 20 |ight>MAX|X. |
|00005fc0| 20 20 72 69 67 68 74 3d | 4d 41 58 58 00 20 20 20 | right=|MAXX. |
|00005fd0| 20 20 20 20 20 80 0b 20 | 6c 65 66 74 3e 4d 41 58 | .. |left>MAX|
|00005fe0| 58 00 20 20 20 20 20 20 | 20 20 20 20 80 be 20 80 |X. | .. .|
|00005ff0| 0b 3a 20 80 05 20 63 6f | 6e 74 69 6e 75 65 33 00 |.: .. co|ntinue3.|
|00006000| 20 20 20 20 20 20 20 20 | 80 c0 00 20 20 20 20 20 | |... |
|00006010| 20 80 c0 00 20 20 20 20 | 20 20 bb 85 20 6c 65 66 | ... | .. lef|
|00006020| 74 2c 20 74 65 6d 70 5f | 79 2c 20 72 69 67 68 74 |t, temp_|y, right|
|00006030| 2c 20 74 65 6d 70 5f 79 | 2c 20 63 00 20 20 20 20 |, temp_y|, c. |
|00006040| 63 6f 6e 74 69 6e 75 65 | 33 3a 00 20 20 20 20 80 |continue|3:. .|
|00006050| 17 20 74 65 6d 70 5f 79 | 00 20 20 20 80 c0 00 80 |. temp_y|. ....|
|00006060| 02 20 80 08 00 00 3b 2d | 2d 2d 2d 2d 2d 2d 2d 2d |. ....;-|--------|
|00006070| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00006080| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00006090| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000060a0| 2d 2d 2d 2d 2d 00 80 08 | 20 53 65 74 54 72 69 61 |-----...| SetTria|
|000060b0| 6e 67 6c 65 43 6f 6c 6f | 72 7b 63 2e 77 7d 00 3b |ngleColo|r{c.w}.;|
|000060c0| 20 53 65 74 73 20 61 20 | 63 6f 6c 6f 72 20 66 6f | Sets a |color fo|
|000060d0| 72 20 75 73 65 20 62 79 | 20 44 72 61 77 54 72 69 |r use by| DrawTri|
|000060e0| 61 6e 67 6c 65 32 44 20 | 66 75 6e 63 74 69 6f 6e |angle2D |function|
|000060f0| 20 62 65 63 61 75 73 65 | 00 3b 20 70 61 72 61 6d | because|.; param|
|00006100| 65 74 65 72 73 20 70 61 | 73 73 65 64 20 74 6f 20 |eters pa|ssed to |
|00006110| 74 68 61 74 20 66 75 6e | 63 74 69 6f 6e 20 67 65 |that fun|ction ge|
|00006120| 74 20 63 6f 72 72 75 70 | 74 65 64 3a 20 42 42 32 |t corrup|ted: BB2|
|00006130| 20 62 75 67 2e 00 3b 00 | 20 20 80 15 20 47 4c 5f | bug..;.| .. GL_|
|00006140| 54 52 49 41 4e 47 4c 45 | 5f 43 4f 4c 4f 52 00 20 |TRIANGLE|_COLOR. |
|00006150| 20 47 4c 5f 54 52 49 41 | 4e 47 4c 45 5f 43 4f 4c | GL_TRIA|NGLE_COL|
|00006160| 4f 52 3d 63 00 80 02 20 | 80 08 00 00 3b 2d 2d 2d |OR=c... |....;---|
|00006170| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00006180| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00006190| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000061a0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 00 2e 44 72 61 |--------|---..Dra|
|000061b0| 77 54 72 69 61 6e 67 6c | 65 32 44 00 80 08 20 44 |wTriangl|e2D... D|
|000061c0| 72 61 77 54 72 69 61 6e | 67 6c 65 32 44 7b 2a 70 |rawTrian|gle2D{*p|
|000061d0| 31 2e 70 69 78 65 6c 2c | 2a 70 32 2e 70 69 78 65 |1.pixel,|*p2.pixe|
|000061e0| 6c 2c 63 6f 6c 6f 72 64 | 75 6d 6d 79 2e 6c 2c 2a |l,colord|ummy.l,*|
|000061f0| 70 33 2e 70 69 78 65 6c | 7d 00 3b 20 44 72 61 77 |p3.pixel|}.; Draw|
|00006200| 73 20 61 20 74 72 69 61 | 6e 67 6c 65 20 6f 6e 20 |s a tria|ngle on |
|00006210| 61 20 73 63 72 65 65 6e | 00 3b 00 20 20 80 33 2e |a screen|.;. .3.|
|00006220| 77 20 78 31 2c 20 79 31 | 2c 20 78 32 2c 20 79 32 |w x1, y1|, x2, y2|
|00006230| 2c 20 78 33 2c 20 79 33 | 2c 20 63 6f 6c 6f 72 00 |, x3, y3|, color.|
|00006240| 20 20 80 33 2e 6c 20 74 | 65 6d 70 5f 78 2c 20 74 | .3.l t|emp_x, t|
|00006250| 65 6d 70 5f 79 2c 20 6e | 65 77 5f 78 2c 20 6d 69 |emp_y, n|ew_x, mi|
|00006260| 6e 79 2c 20 6d 61 78 79 | 2c 20 6d 69 6e 78 2c 20 |ny, maxy|, minx, |
|00006270| 6d 61 78 78 00 20 20 80 | 33 2e 70 69 78 65 6c 20 |maxx. .|3.pixel |
|00006280| 71 31 2c 20 71 32 2c 20 | 71 33 00 20 20 80 15 20 |q1, q2, |q3. .. |
|00006290| 4d 49 4e 58 2c 20 4d 49 | 4e 59 2c 20 4d 41 58 58 |MINX, MI|NY, MAXX|
|000062a0| 2c 20 4d 41 58 59 2c 20 | 47 4c 5f 54 52 49 41 4e |, MAXY, |GL_TRIAN|
|000062b0| 47 4c 45 5f 43 4f 4c 4f | 52 00 00 20 20 78 31 3d |GLE_COLO|R.. x1=|
|000062c0| 2a 70 31 5c 78 3a 20 79 | 31 3d 2a 70 31 5c 79 3a |*p1\x: y|1=*p1\y:|
|000062d0| 20 78 32 3d 2a 70 32 5c | 78 3a 20 79 32 3d 2a 70 | x2=*p2\|x: y2=*p|
|000062e0| 32 5c 79 3a 20 78 33 3d | 2a 70 33 5c 78 3a 20 79 |2\y: x3=|*p3\x: y|
|000062f0| 33 3d 2a 70 33 5c 79 00 | 00 20 20 63 6f 6c 6f 72 |3=*p3\y.|. color|
|00006300| 3d 47 4c 5f 54 52 49 41 | 4e 47 4c 45 5f 43 4f 4c |=GL_TRIA|NGLE_COL|
|00006310| 4f 52 00 00 20 20 3b 74 | 65 73 74 20 66 6f 72 20 |OR.. ;t|est for |
|00006320| 68 20 6c 69 6e 65 73 20 | 61 6e 64 20 76 20 6c 69 |h lines |and v li|
|00006330| 6e 65 73 00 20 20 80 0b | 20 28 28 78 31 3d 78 32 |nes. ..| ((x1=x2|
|00006340| 20 80 42 20 78 32 3d 78 | 33 29 20 80 8a 20 28 79 | .B x2=x|3) .. (y|
|00006350| 31 3d 79 32 20 80 42 20 | 79 32 3d 79 33 29 29 20 |1=y2 .B |y2=y3)) |
|00006360| 80 21 20 80 08 20 80 07 | 00 00 20 20 3b 73 6f 72 |.! .. ..|.. ;sor|
|00006370| 74 20 70 31 2c 20 70 32 | 20 61 6e 64 20 70 33 20 |t p1, p2| and p3 |
|00006380| 69 6e 20 61 73 63 65 6e | 64 69 6e 67 20 79 20 6f |in ascen|ding y o|
|00006390| 72 64 65 72 00 20 20 80 | 0b 20 79 32 3c 79 31 00 |rder. .|. y2<y1.|
|000063a0| 20 20 20 20 74 65 6d 70 | 5f 78 3d 78 32 00 20 20 | temp|_x=x2. |
|000063b0| 20 20 74 65 6d 70 5f 79 | 3d 79 32 00 20 20 20 20 | temp_y|=y2. |
|000063c0| 78 32 3d 78 31 00 20 20 | 20 20 79 32 3d 79 31 00 |x2=x1. | y2=y1.|
|000063d0| 20 20 20 20 78 31 3d 74 | 65 6d 70 5f 78 00 20 20 | x1=t|emp_x. |
|000063e0| 20 20 79 31 3d 74 65 6d | 70 5f 79 00 20 20 80 c0 | y1=tem|p_y. ..|
|000063f0| 00 20 20 80 0b 20 79 33 | 3c 79 31 00 20 20 20 20 |. .. y3|<y1. |
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.